1.问题:
写角色页面,就是我循环出select内的数据以后,发现原本默认显示第一条的select框变成了空白
2.解决思路:
html代码如下,通过v-model可以获取到选中的值,如果option中存在value属性,优先获取value值即coupon.id,如果不存在,则获取option的文本内容,也就是下面代码中coupon.name.
3.大神的Demo参考:
<select name="public-choice" v-model="couponSelected" @change="getCouponSelected">
<option :value="coupon.id" v-for="coupon in couponList" >{{coupon.name}}</option>
</select>
首先说明,html这样写没有任何问题,动态的select的正确使用方法就是这样。
下面是js代码:
var vm = new Vue({
el: '#app',
data:{
couponList:[
{
id: 'A',
name: '优惠券1'
},
{
id: '1',
name: '优惠券2'
},
{
id: '2',
name: '优惠券3'
}
],
couponSelected: '',
},
created(){
//如果没有这句代码,select中初始化会是空白的,默认选中就无法实现
this.couponSelected = this.couponList[0].id;
},
methods:{
getCouponSelected(){
//获取选中的优惠券
console.log(this.couponSelected)
}
}
})
上面的js代码是正确的,我下面说明一下隐藏属性是什么
隐藏属性就是
当我们把v-model中的couponSelected,也就是data里的couponSelected的值赋值为循环的option中的value后,那这个option就会被默认选中
4.小结
官方参考文档:https://cn.vuejs.org/v2/guide/forms.html
以上demo参考链接:https://www.cnblogs.com/till-the-end/p/8473738.html
5.实际尝试操作:
遇到的问题,第一次赋值可以,然后打开第二行信息的收应该是空,实际是admin,
怀疑是赋值问题,打开时默认赋值时是空的,然后再查询一次后赋值,或者是直接当前角色信息,空为空,值为值。
<template> <div> <!--添加按钮--> <el-row style="padding: 10px 0;"> <el-col :span="20" :offset="2"> <el-button type="info" @click="handleAdd()">添加用户</el-button> </el-col> </el-row> <!--列表展示部分--> <el-row style="padding: 10px 0;"> <el-col :span="20" :offset="2"> <el-table :data="dataList" border v-loading.body="isTableLoading" style="width: 100%"> <el-table-column label="用户名字"> <template scope="scope"> <span style="margin-left: 10px">{{ scope.row.name }}</span> </template> </el-table-column> <el-table-column label="邮箱"> <template scope="scope"> <span style="margin-left: 10px">{{ scope.row.email }}</span> </template> </el-table-column> <el-table-column label="状态" width="100px"> <template scope="scope"> <span style="margin-left: 10px"> <el-tag v-if=" scope.row.status == 0 " type="warning">未激活</el-tag> <el-tag v-if=" scope.row.status == 1 " type="success">正常</el-tag> <el-tag v-if=" scope.row.status == 2 " type="danger">冻结</el-tag> </span> </template> </el-table-column> <el-table-column label="上次登陆时间"> <template scope="scope"> <span v-if="scope.row.lastLoginTime" style="margin-left: 10px">{{ scope.row.lastLoginTime | TimeFormat }}</span> </template> </el-table-column> <el-table-column label="操作" width="400px;"> <template scope="scope"> <el-button v-if="scope.row.status == 1" size="small" type="danger" @click="handleFreeze(scope.row.id, 2, scope.$index)">冻结 </el-button> <el-button v-if="scope.row.status == 2" size="small" type="success" @click="handleFreeze(scope.row.id, 1, scope.$index)">解冻 </el-button> <el-button size="small" type="danger" @click="handleDelete(scope.row.id, scope.$index)">删除 </el-button> <el-button size="small" type="warning" @click="handleModify(scope.row)">修改 </el-button> <el-button size="small" type="warning" @click="shandleModify(scope.row)">查看 </el-button> <el-button size="small" type="warning" @click="setRole(scope.row.id,scope.row.roleId,scope.row.role_name)">设置角色 </el-button> </template> </el-table-column> </el-table> </el-col> </el-row> <!--分页--> <el-row> <el-col :span="24" style="text-align:center"> <el-pagination style="text-align:center;margin-top:20px" @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="pageNum" :page-sizes="[5, 10, 20, 50]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="totalCount"> </el-pagination> </el-col> </el-row> <!--增加和修改模块部分--> <el-dialog :title="title" :visible.sync="addUserVisible" size="tiny"> <el-form :model="inviteForm" :rules="inviteRules" ref="inviteForm"> <el-form-item label="用户名字" :label-width="formLabelWidth" prop="name"> <el-input v-model="inviteForm.name" auto-complete="off"></el-input> </el-form-item> <el-form-item label="用户邮箱" :label-width="formLabelWidth" prop="email"> <el-input v-model="inviteForm.email" auto-complete="off"></el-input> </el-form-item> <el-form-item label="用户电话" :label-width="formLabelWidth" prop="telephone"> <el-input v-model="inviteForm.telephone" auto-complete="off"></el-input> </el-form-item> </el-form> <div slot="footer" class="dialog-footer"> <el-button @click="addUserVisible = false">取 消</el-button> <el-button type="primary" @click="handleInviteUser()" :loading="isInviting">确 定</el-button> </div> </el-dialog> <!--查看部分--> <el-dialog :title="title" :visible.sync="addUserVisible1" size="tiny"> <el-form :model="inviteForm1" :ref="inviteForm1"> <el-form-item label="用户名字" :label-width="formLabelWidth" prop="name"> <span style="margin-left: 10px">{{inviteForm1.name}}</span> </el-form-item> <el-form-item label="用户邮箱" :label-width="formLabelWidth" prop="email"> <span style="margin-left: 10px">{{inviteForm1.email}}</span> </el-form-item> <el-form-item label="用户电话" :label-width="formLabelWidth" prop="telephone"> <span style="margin-left: 10px">{{inviteForm1.telephone}}</span> </el-form-item> </el-form> <div slot="footer" class="dialog-footer"> <el-button @click="addUserVisible1 = false">确 定</el-button> </div> </el-dialog> <!--设置角色--> <el-dialog :title="title" :visible.sync="addUserVisible2" size="tiny"> <el-form :model="inviteForm2" :ref="inviteForm2"> <div style="display:none;">{{inviteForm2.id}}</div> <select name="public-choice" v-model ="roleSelected" style="width: 200px;" autocomplete="off" @change ="changeRole($event)"> <option value="" >请选择</option> <option :value="role.id" v-for="role in roleList" > {{ role.role_name }} </option> </select> </el-form> <div slot="footer" class="dialog-footer"> <el-button @click="saveRole()">确 定</el-button> </div> </el-dialog> </div> </template> <script> import { mapActions } from 'vuex' export default { data(){ //校验邮箱 const emailValidator = (rule, value, callback)=>{ if((/^[-a-z0-9~!$%^&*_=+}{\'?]+(\.[-a-z0-9~!$%^&*_=+}{\'?]+)*@([a-z0-9_][-a-z0-9_]*(\.[-a-z0-9_]+)*\.(aero|arpa|biz|com|coop|edu|gov|info|int|mil|museum|name|net|org|pro|travel|mobi|[a-z][a-z])|([0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}))(:[0-9]{1,5})?$/i.test(value))){ callback() }else{ callback(new Error('请输入正确的邮箱地址')) } } return { isInviting:false,//增加页面和修改页面 addUserVisible:false,//增加和修改页面 addUserVisible1:false,//查看页面 addUserVisible2:false,//角色选择页面 isTableLoading:false,//列表加载 title:'',//所有弹出层的共用title currentUserInfo:null,//当前用户信息 roleSelected:'',//设置select选中 option:'', inviteForm:{//增加和修改页面的字段信息 name:"", email:"", telephone:"" }, inviteForm1:{//查看页面的字段信息 name:"", email:"", telephone:"" }, inviteForm2:{//角色选择页面的字段信息 id:"",//当前选中用户的id roleId:"",//当前用户选中的角色的id }, formLabelWidth:"80px",//设置宽度 dataList:[],//列表加载的集合 roleList: [],//角色选择的集合 pageSize: 10,//分页信息-每页多少 totalCount:0,//分页信息-总共多少页 pageNum:1,//第几页 inviteRules:{//增加或修改页面的校验规则 name: [ { required: true, message: '请输入用户名字', trigger: 'blur' } ], email: [ { required: true, validator: emailValidator, trigger: 'blur' } ], } } }, //初始化加载并获取用户列表(ok) mounted: function () { this.isTableLoading = true; this.getUserList({ pageSize: this.pageSize, pageNum: this.pageNum }).then((result) => { this.isTableLoading = false; this.totalCount = result.totalCount; this.dataList = result.resultData; console.log(this.dataList); }, () => { this.isTableLoading = false; this.$message.error('列表加载失败!'); }) }, methods:{ ...mapActions([ 'getUserList', 'updateUser', 'deleteUser', 'inviteUser', 'getUserById', 'getRoleList', 'getRoleInfo', ]), //点击增加用户的按钮(ok) handleAdd(){ this.addUserVisible = true, this.title = '增加用户', this.inviteForm = { name:"", email:"",telephone:"" }; this.currentUserInfo = null }, //修改用户的按钮(ok) handleModify(data){ this.title = '修改用户'; this.addUserVisible = true; this.currentUserInfo = data; this.getUserById({ id: data.id }) .then((result) => { this.inviteForm = { name:data.name, email:data.email, telephone:data.telephone } }, () => {}) }, //查看按钮(ok) shandleModify(data){ this.title = '查看用户'; this.addUserVisible1 = true; this.getUserById({ id: data.id }) .then((result) => { this.inviteForm1 = { name:data.name, email:data.email, telephone:data.telephone } }, () => {}) }, //执行增加或者修改(ok) handleInviteUser(){ this.$refs['inviteForm'].validate((valid) => { if (valid) { this.isInviting = true; this.isTableLoading = true; (()=>{ if(this.currentUserInfo){ this.inviteForm.id = this.currentUserInfo.id; return this.updateUser(this.inviteForm) }else{ return this.inviteUser(this.inviteForm) } })() .then(()=>{ this.isInviting = false; this.addUserVisible = false; this.inviteForm = { name:"", email:"",telephone:"" }; this.$message({ message: this.title+'成功', type: 'success' }); this.isTableLoading = true; this.getUserList({ pageSize:this.pageSize, pageNum:this.pageNum }).then((result) => { this.isTableLoading = false; this.totalCount = result.totalCount; this.dataList = result.resultData; }, () => { this.isTableLoading = false; this.$message.error('列表加载失败!'); }) },()=>{ this.isInviting = false; this.$message({ message: this.title+'失败', type: 'error' }); }) } }) }, //删除用户(ok) handleDelete(userId, index) { this.$confirm('此操作将永久删除数据, 是否继续?', '提示', { confirmButtonText: '确定', cancelButtonText: '取消', type: 'warning' }).then(() => { this.isTableLoading = true; this.deleteUser({ id: userId }) .then(() => { this.getUserList({ pageSize: this.pageSize, pageNum: this.pageNum }) .then((result) => { this.isTableLoading = false; this.totalCount = result.totalCount; this.dataList = result.resultData; this.$message({ type: 'success', message: '删除成功!' }); }, () => { this.isTableLoading = false; this.$message.error('列表刷新失败!'); }) }, () => { this.$message({ type: 'error', message: '删除失败!' }); }) }).catch(() => { this.$message({ type: 'info', message: '已取消删除' }); }); }, //冻结或者解冻用户 handleFreeze(userId, status, index){ this.isTableLoading = true; this.updateUser({ id:userId, status:status }) .then((result) => { this.isTableLoading = false; this.dataList[index].status = status; this.$message({ message: '修改成功!', type: 'success' }); }, () => { this.isTableLoading = false; this.$message.error('修改失败!'); }) }, //获取用户的所有角色的按钮(ok) setRole(id,roleId,role_name){ //调用方法获取角色列表 this.user_id = id;//获取角色id this.addUserVisible2 = true; this.title = '选择角色'; this.getRoleList({//调用方法获取所有角色的列表 }) .then((result) => { this.isTableLoading = false; this.roleList = result.resultData; //console.log("当前角色列表"+this.roleList); //如果没有这句代码,select中初始化会是空白的,默认选中就无法实现 //this.roleSelected = this.roleList[0].id; //console.log("当前选中角色id:"+this.roleSelected); this.roleSelected = roleId;//设置默认选中的值 }, () => { this.isTableLoading = false; this.$message.error('列表加载失败!'); }) }, //获取每次option选中时的id(ok) changeRole(event) { this.option = event.target.value; //获取ID,即option对应的ID值 console.log("变更后的角色"+this.option); }, //增加用户的角色(ok) saveRole(){ this.addUserVisible2 = false; //调用方法给角色赋值 //alert(this.option); this.inviteForm2 = { id:this.user_id, roleId:this.option}; this.updateUser(this.inviteForm2) }, //分页 handleSizeChange(pageSize){ this.pageSize = pageSize; this.pageNum = 1; this.isTableLoading = true; this.getUserList({ pageSize:this.pageSize, pageNum:this.pageNum }) .then((result) => { this.isTableLoading = false; this.totalCount = result.totalCount; this.dataList = result.resultData; }, () => { this.isTableLoading = false; this.$message.error('列表加载失败!'); }) }, //分页 handleCurrentChange(pageNum){ this.pageNum = pageNum; this.isTableLoading = true; this.getUserList({ pageSize:this.pageSize, pageNum:this.pageNum }) .then((result) => { this.isTableLoading = false; this.totalCount = result.totalCount; this.dataList = result.resultData; }, () => { this.isTableLoading = false; this.$message.error('列表加载失败!'); }) }, //修改角色的按钮 } } </script> <style lang="less" scoped> </style>