beforeMount要放到method外面,平行的地位MAIN

<template>
    <div>
    <el-main>
        <div>
            <el-input v-model="name" placeholder="请输入名字" style="width: 200px;" suffix-icon="el-icon-search"
                    @keyup.enter.native="loadPost"></el-input>
            <el-select v-model="sex" filterable placeholder="请选择性别" style="margin-left:5px;">
                <el-option
                    v-for="item in sexs"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value">
                </el-option>
            </el-select>

            <el-button type="primary" style="margin-left: 5px;" @click="loadPost">查询</el-button>
            <el-button type="danger" @click="resetParam">重置</el-button>
            <el-button type="danger" @click="add">新增</el-button>
        </div>

      <el-table :data="tableData"
      :header-cell-style="{background:'#bbbbbb'}">
            <el-table-column prop="id" label="ID" width="60">
            </el-table-column>
            <el-table-column prop="no" label="账号" width="60">
            </el-table-column>
            <el-table-column prop="name" label="姓名" width="180">
            </el-table-column>
            <el-table-column prop="age" label="年龄" width="60">
            </el-table-column>
            <el-table-column prop="sex" label="性别" width="60">
                <template slot-scope="scope">
                    <el-tag 
                    :type="scope.row.sex === 1 ? 'primary' : 'success'"
                        disable-transitions>{{scope.row.sex === 1 ? '男' : '女'}}
                    </el-tag>
                </template>
            </el-table-column>
            <el-table-column prop="phone" label="电话" width="60">
            </el-table-column>
            <el-table-column prop="roleId" label="角色号" width="120">
                <template slot-scope="scope">
                    <el-tag 
                    :type="scope.row.roleId === 0 ? 'danger' : (scope.row.roleId === 1 ? 'primary' : 'success')"
                        disable-transitions>{{scope.row.roleId === 0 ? '超级管理员' : (scope.row.roleId === 1 ? '管理员' : '普通用户')}}
                    </el-tag>
                </template>
            </el-table-column>
            <el-table-column prop="isvalid" label="是否生效" width="60">
            </el-table-column>

            <el-table-column prop="operate" label="操作" width="200">
                <template slot-scope="scope">
                    <el-button size="small" type="success" @click="mod(scope.row)">编辑</el-button>
                    <el-button size="small" type="danger" @click="del(scope.row.id)">删除</el-button>
                </template>
            </el-table-column>
      </el-table>
    </el-main>
    <el-pagination
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="pageNum"
      :page-sizes="[ 5, 10, 20]"
       
      :page-size="pageSize"
      layout="total, sizes, prev, pager, next, jumper"
      :total="total">
    </el-pagination>

    <el-dialog
    title="提示"
    :visible.sync="centerDialogVisible"
    width="30%"
    center>
    <span>
        <el-form ref="form" :model="form" :rules="rules"   label-width="100px" >
            <el-form-item label="账号" prop="no">
                <el-col :span="15">
                    <el-input v-model="form.no"></el-input>
                </el-col>
            </el-form-item>
            <el-form-item label="密码" prop="password">
                <el-col :span="15">
                    <el-input v-model="form.password"></el-input>
                </el-col>
            </el-form-item>
            <el-form-item label="姓名" prop="name">
                <el-col :span="15">
                    <el-input v-model="form.name"></el-input>
                </el-col>
            </el-form-item>
            
            <el-form-item label="年龄" prop="age">
                <el-col :span="15">
                    <el-input v-model="form.age"></el-input>
                </el-col>
            </el-form-item>
            <el-form-item label="性别" prop="sex">
                <el-radio-group v-model="form.sex">
                    <el-radio label="1">男</el-radio>
                    <el-radio label="0">女</el-radio>
                </el-radio-group>
            </el-form-item>
            <el-form-item label="电话" prop="phone">
                <el-col :span="15">
                    <el-input v-model="form.phone"></el-input>
                </el-col>
            </el-form-item>
        </el-form>

  </span>
  <span slot="footer" class="dialog-footer">
    <el-button @click="centerDialogVisible = false">取 消</el-button>
    <el-button type="primary" @click="saveormod">确 定</el-button>
  </span>
</el-dialog>
</div>
</template>


<script>
  export default {

    data() {
        let checkAge = (rule, value, callback) => {
            if(value>150){
                callback(new Error('年龄输⼊过⼤'));
            }else{
                callback();
            }
        };
        let checkDuplicate =(rule,value,callback)=>{
            if(this.form.id){
            return callback();
            }
            this.$axios.get(this.$httpUrl+ "/user/findByNo?no="+this.form.no).then(res=>res.data).
            then(res=>{
                console.log(res)

            if(res.code!=200){
                callback()
            }else{
                callback(new Error('账号已经存在wsm'));
            }
            })
        };

      return {
        tableData: [],
        pageSize:5,//这如果比较小,而且page-sizes="[5, 10, 20]"中没有
        //,就会导致初始界面无法显示完整数据
        pageNum:1,
        total:5,
        name:'',
        sex:'',
        sexs: [{
          value: '1',
          label: '男'
        }, {
          value: '0',
          label: '女'
        }],
        centerDialogVisible: false,
        form:{
            id:'',
            no:'',
            password:'',
            name:'',
            age:'',
            phone:'',
            sex:''
        },
        rules: {
          no: [
            { required: true, message: '请输入账号no', trigger: 'blur' },
            { min: 3, max: 8, message: '长度在 3 到 8 个字符', trigger: 'blur' },
            {validator:checkDuplicate,trigger: 'blur'}
        ],
          name: [
            { required: true, message: '请输入name', trigger: 'blur' },
          ],
          password: [
            { required: true, message: '请输入密码password', trigger: 'blur' },
            { min: 3, max: 8, message: '长度在 3 到 8 个字符', trigger: 'blur' }
          ],
          age: [
            {required: true, message: '请输⼊年龄', trigger: 'blur'},
            {min: 1 , max: 3, message: '⻓度在 1 到 3 个位', trigger: 'blur'},
            {pattern: /^([1-9][0-9]*){1,3}$/,message: '年龄必须为正整数字',trigger: "blur"},
            {validator:checkAge,trigger: 'blur'}
            ],
          phone: [
            {required: true,message: "⼿机号不能为空",trigger: "blur"},
            {pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, message: "请输⼊正确的⼿机号码", trigger:
            "blur"}
            ]
        }   

      }

    },
    beforeMount(){
            this.loadGet();
            //this.loadPost();
            console.log('这个自动执行了吗?');
            alert('真的执行了吗?')
            // this.pageNum=1;
            // this.pageSize=2;
        },
    methods:{
        loadGet(){
            this.$axios.get(this.$httpUrl+'/user/list').then(res=>res.data).then(res=>{
                console.log(res)
                this.tableData=res
            })
        },
        loadPost(){
            this.$axios.post(this.$httpUrl+'/user/listPageC1',{
        
                pageNum:this.pageNum,
                pageSize:this.pageSize,
                param:{
                    name:this.name,
                    sex:this.sex
                }
            
             }).then(res=>res.data).then(res=>{
                console.log(res)
                if(res.code==200){
                    this.tableData=res.data
                    this.total=res.total
                    //这里要去看看网页打印的res到底是什么东西
                    //然后看怎么获取表格需要的数据
                    //成功后设置已知的参数
                    //this.tableData=res
                }else{
                    alert('获取数据失败')
                }
                
            })
        },
        resetParam(){
            this.name=null;
            this.sex=null;
            this.loadPost();
        },
        handleSizeChange(val) {
            console.log(`每页 ${val} 条`);
            this.pageNum=1;
            this.pageSize=val;
            this.loadPost();
        },
        handleCurrentChange(val) {
            console.log(`当前页: ${val}`);
            this.pageNum=val;
            this.loadPost();
        },
            
        // beforeMount(){
        //     this.loadGet();
        //     //this.loadPost();
        //     console.log('这个自动执行了吗?');
        //     alert('真的执行了吗?')
        //     // this.pageNum=1;
        //     // this.pageSize=2;
        // },
        add(){
           
            this.centerDialogVisible=true;
            this.$nextTick(()=>{
                this.resetForm(form);
            })
        },
        saveormod(){
            this.$refs.form.validate((valid) => {
                if (valid)
                {
                    if(this.form.id){
                        this.doMod();
                    }else{
                        this.doSave();
                    }
                } else{
                    console.log('error submit!');
                    return false;
                }  
            })
           
        },
        doSave(){
            this.$axios.post(this.$httpUrl+'/user/save',this.form).then(res=>res.data)
            .then(res=>{
                console.log(res)
                if(res.code==200){ 
                    this.$message({
                    message: '恭喜你,这是一条成功消息',
                    type: 'success'
                    });  
                    this.centerDialogVisible=false;
                    this.loadPost();
                    this.resetForm();
                }else{
                    this.$message.error('错了哦,这是一条错误消息')
                    
                }       
            })
        },
        doMod(){
            this.$axios.post(this.$httpUrl+'/user/update',this.form).then(res=>res.data)
            .then(res=>{
                console.log(res)
                if(res.code==200){ 
                    this.$message({
                    message: '恭喜你,这是一条成功消息',
                    type: 'success'
                    });  
                    this.centerDialogVisible=false;
                    this.loadPost();
                    this.resetForm();
                }else{
                    this.$message.error('错了哦,这是一条错误消息')
                    
                }       
            })
        },
        save(){
            
            this.$refs.form.validate((valid) => {
            if (valid) {
           

            this.$axios.post(this.$httpUrl+'/user/save',this.form).then(res=>res.data)
            .then(res=>{
                console.log(res)
                if(res.code==200){ 
                    this.$message({
                    message: '恭喜你,这是一条成功消息',
                    type: 'success'
                    });  
                    this.centerDialogVisible=false;
                    this.loadPost();
                    this.resetForm();
                }else{
                    this.$message.error('错了哦,这是一条错误消息')
                    
                }       
            })

          } else {
            console.log('error submit!!');
            return false;
          }
        });
        },
        mod(row){
            console.log(row)
            this.centerDialogVisible=true;
            //赋值到表单

            this.$nextTick(()=>{
                this.form.id = row.id;
                this.form.no = row.no;
                this.form.name = row.name;
                this.form.password = "";
                this.form.phone = row.phone;
                this.form.sex = row.sex;
                this.form.roleId = row.sroleId;
                // this.resetForm(form);
            })
            
        },
        del(id){
            this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
            confirmButtonText: '确定',
            cancelButtonText: '取消',
            type: 'warning'
        }).then(() => {
          this.$message({
            type: 'success',
            message: '删除成功!'
          });
          console.log(id);
          this.$axios.get(this.$httpUrl+'/user/del?id='+id).then(res=>res.data)
            .then(res=>{
                console.log(res)
                if(res.code==200){ 
                    this.$message({
                    message: '恭喜你,这是一条成功消息',
                    type: 'success'
                    });     
                }else{
                    this.$message.error('错了哦,这是一条错误消息')
                }       
            })
        }).catch(() => {
          this.$message({
            type: 'info',
            message: '已取消删除'
          });          
        });
        },
        resetForm() {
            this.$refs.form.resetFields();
      }
    }   
};
    
</script>
  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值