项目四:后台用户管理系统(四):实现用户添加功能时遇到的问题

好家伙,

 

在实现“添加用户”这个功能的时候,遇到了许多问题

 

在MyUsers.vue组件中,(就不展开了)

<template>
  <div>
    <!-- 标题 -->
    <h4 class="text-center">用户管理</h4>

    <!-- 用户列表 -->
    <table class="table table-bordered table-striped table-hover">
      <thead>
        <tr>
          <th>id</th>
          <th>姓名</th>
          <th>年龄</th>
          <th>头衔</th>
          <th>操作</th>
        </tr>
      </thead>
      <tbody>
        <tr v-for="item in userlist" :key="item.id">
          <td>{{item.id}}</td>
          <td>{{item.name}}</td>
          <td>{{item.age}}</td>
          <td>{{item.position}}</td>
          <td>
            <a href="" @click.prevent="gotoDetail(item.id)">详情</a>
          </td>
        </tr>
      </tbody>
    </table>
    <button @click="addUser">添加用户</button>
  </div>
</template>

<script>
import bus from "../user/eventbus"
export default {
  name: 'MyUser',
  data() {
    return {
      // 用户列表数据
      userlist: [
        { id: 1, name: '胖虎', age: 20, position: '程序员' },
        { id: 2, name: '蔡宇', age: 18, position: '大叔' },
      
      ],
      name:"",
      age:""
    }
  },
  methods: {
    gotoDetail(id) {
      this.$router.push('/home/detail/'+id)
    },
    addUser(){
      this.$router.push('/home/addUser')
    }
  },
  created(){
        //2.为bus绑定自定义事件,(绑定事件)
        bus.$on('share',(val,vall)=>{
            console.log("Left组件传过来的值为:",val,vall)
            this.name=val;
            this.password=vall;
            this.userlist.push({id:3,name:val,age:vall,position:vall});
            this.userlist.push({id:4,name:val,age:vall,position:vall});
            console.log(this.userlist)

        })
     //将收到的val值打印并且将val的值赋给组件的参数
    },
  beforeMount(){
    // this.userlist.push({id:3,name:this.name,age:this.name,position:this.name});
  },
  mounted(){
    this.userlist.push({id:3,name:this.name,age:this.name,position:this.name});
  },
  beforeUpdate(){
    
  }
}
</script>

<style lang="less" scoped></style>
View Code

在组件AddUser.vue中,

<template>
  <div>
    <h2>用户:</h2>
    <input type="" v-model="name">
    <h2>密码:</h2>
    <input type="" v-model="password">
    <button @click="send">创建新用户</button>
    <button @click="addUserr">拿数据</button>

  </div>
</template>


<script>
import bus from "./eventbus.js"
export default {
    data(){
        return{
            name:"",
            password:"",
        }
    },
    methods:{
        addUser(){

        },
        addUserr(){
            console.log(this.name+"  "+this.password)
        },
        send(){
            bus.$emit('share',this.name,this.password)
            alert("传值成功",this.name,this.password)
            this.$router.push('/home/Users')
        }
    }
    }


</script>
View Code

 

两组件为兄弟组件关系

我使用的兄弟组件传值方案为eventbus(技术有限,只能用这个)

 

来看看这个代码:

created(){
        //2.为bus绑定自定义事件,(绑定事件)
        bus.$on('share',(val,vall)=>{
            console.log("Left组件传过来的值为:",val,vall)
            this.name=val;
            this.password=vall;
            this.userlist.push({id:3,name:val,age:vall,position:vall});
            console.log(this.userlist)

        })
     //将收到的val值打印并且将val的值赋给组件的参数
    },

 

在实现“添加用户”这个功能的时候,遇到了许多问题

 

 

我理所当然在created方法中,进行了数组的push方法

 

 

 

然后,结果当然是,寄.

 

来看看控制台吧

 

 

 

 

 

 可以看出来

组件传值成功了,数组添加方法也成功了,

那么大概率是视图的问题了

换个生命周期钩子试试

 

created(){
        //2.为bus绑定自定义事件,(绑定事件)
        bus.$on('share',(val)=>{
           
            this.user=val;
            
            this.userlist.push(this.user);

            this.$forceUpdate();

            this.__watchers.userlist.dirty=true

            console.log(this.userlist)

        })
        //将收到的val值打印并且将val的值赋给组件的参数
    },
  // // beforeMount(){
  // //   this.userlist.push(this.user);
  // // },
  // mounted(){
  //     // if(this.a=2){
  //     // this.userlist.push(this.user);
  //     // }
  // },
  // beforeUpdate(){
  //     // this.userlist.push(this.user);
  //   },

  // updated(){
  //     // this.userlist.push(this.user);
  // }

把每个钩子都试一遍

 

 

 

麻了,用beforemount钩子,有id没数据

依旧寄

 

在咨询大佬后

 

尝试另辟蹊径

 

this.$forceUpdate();

this.__watchers.userlist.dirty=true

 

还是寄

 

暂未解决,待续

posted @ 2022-07-08 23:36  养肥胖虎  阅读(101)  评论(0编辑  收藏  举报