Vue select 绑定动态变量的实例讲解


Posted in Javascript onOctober 22, 2020

概述

根据后台的数据生成多个select,由于数据的数量不定,所以v-model绑定的变量名也不定。所以通过数据的id或者下标进行变量拼接。页面能够成功渲染,但是当进行下拉框的选值时,组件不刷新,选中的结果并没有展示

Code

<div v-for="(item, index) in tagAllDate" :key="index">
    <el-form-item :label="item.name">
     <el-select v-model="editData['line_' + index]" multiple placeholder="请选择" style="width: 100%;">
      <el-option v-for="(itemO, o) in item.sub_list" :key="o" :label="itemO.name" :value="itemO.tag_id"></el-option>
     </el-select>
    </el-form-item>
   </div>

editdata是声明的对象

editData:{},

由于我们需要进行变量的动态拼接,所以不能使用“对象.属性”这种语法,使用中括号[]可以方便我们进行属性名的动态拼接。因为属性名并不能提前知道,所以editData中不能提前声明变量。而这就是问题的关键所在。

问题

由于v-model绑定的值没有声明,所以组件渲染后,当进行下拉选择时,选项的值并没有显示在组件中。但是输出结果时,值已经被选中了。也就是说,能够选到值,但页面上组件无响应。

如果假定我们拼接的id为[1,2,3] ,所以变量名为line_1, line_2, line_3 。在editData中依次声明这些变量后,组件显示正常。

结论

el-select组件需要绑定明确的变量,如果变量没有提前声明,则组件选择时界面将会无响应。

解决方案

tagAll() {
    this.loading = true;
    tagAll().then(response => {
     if(response.ret == 0) {
      response.data.forEach( (item, index)=>{
        this.$set(this.editData, "line_" + index, [])
      });
      this.tagAllDate = response.data;
     } else {
      this.$message.error(response.res_info);
     }
     this.loading = false
    })
   },

按照官方说明,在初始化的时候,会生成属性的getter、setter。通过setter函数的调用,从而触发组件更新。而直接赋值,并没有setter函数的触发。

另一个问题,

editData是动态的,里面的 line_ 也是动态的,如何去获取这些信息呢

Vue select 绑定动态变量的实例讲解

对象是editDate。但是里面的line_0 是动态创建的,就是说,editDate里面有多少的数据不知道,可能是:line_0 line_1 line_2 然后这些每一个都是数组,现在要拿到这些所有的数组里面的数据。

做法

首先循环这个对象拿到所有的Key的值,就是 line_0 line_1 这些key

for(var a in this.editData){
 console.log(a);
}

拿到key之后便可以直接根据动态的key拿到数组循环拿相应的值

for(var a in this.editData){
     this.editData[a].forEach( (item, index) => {
      console.log(item)
     });
    }

补充知识:vue-element-admin使用常见问题

一、vue-element-admin添加快捷导航

Vue select 绑定动态变量的实例讲解

这个组件是基于vue-i18n因此,首先在项目中安装i18n

npm install --save vue-i18n

然后main.js中引入

import i18n from './lang' // Internationalization

然后注意src下边lang文件夹的引入。之后在layout文件夹中,添加组件:tags-view 就可以了。

二、去掉Mock使用真实数据。

main.js中找到,mock的引入直接注释掉,就好了。所有的接口请求都在 api 下边

以上这篇Vue select 绑定动态变量的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
xml转json的js代码
Aug 28 Javascript
javascript制作的cookie封装及使用指南
Jan 02 Javascript
JavaScript编写推箱子游戏
Jul 07 Javascript
js代码实现随机颜色的小方块
Jul 30 Javascript
老生常谈JavaScript 正则表达式语法
Aug 20 Javascript
AngularJS使用ng-options指令实现下拉框
Aug 23 Javascript
详解Javascript几种跨域方式总结
Feb 27 Javascript
vue.js实现刷新当前页面的方法教程
Jul 05 Javascript
利用jQuery+localStorage实现一个简易的计时器示例代码
Dec 25 jQuery
Vue export import 导入导出的多种方式与区别介绍
Feb 12 Javascript
vue中destroyed方法的使用说明
Jul 21 Javascript
jquery插件实现图片悬浮
Apr 16 jQuery
在Vue中使用Select选择器拼接label的操作
Oct 22 #Javascript
JavaScript 中判断变量是否为数字的示例代码
Oct 22 #Javascript
关于vue属性使用和不使用冒号的区别说明
Oct 22 #Javascript
jquery实现抽奖功能
Oct 22 #jQuery
Vue实现简单的留言板
Oct 23 #Javascript
Vue+Bootstrap收藏(点赞)功能逻辑与具体实现
Oct 22 #Javascript
JavaScript实现简易计算器小功能
Oct 22 #Javascript
You might like
php visitFile()遍历指定文件夹函数
2010/08/21 PHP
php实现微信企业号支付个人的方法详解
2017/07/26 PHP
ThinkPHP5.0框架控制器继承基类和自定义类示例
2018/05/25 PHP
JavaScript库 开发规则
2009/01/31 Javascript
Firefox div高度自适应
2009/04/28 Javascript
jquery 1.3.2 IE8中的一点点的小问题解决方法
2009/07/10 Javascript
为JavaScript提供睡眠功能(sleep) 自编译JS引擎
2010/08/16 Javascript
在JavaScript中获取请求的URL参数
2010/12/22 Javascript
Js注册协议倒计时的小例子
2013/06/24 Javascript
JS和函数式语言的三特性
2014/03/05 Javascript
Area 区域实现post提交数据的js写法
2014/04/22 Javascript
jQuery实现默认是闭合的FAQ展开效果菜单
2015/09/14 Javascript
Jquery1.9.1源码分析系列(六)延时对象应用之jQuery.ready
2015/11/24 Javascript
jQuery stop()用法实例详解
2016/07/28 Javascript
原生JS版和jquery版实现checkbox的全选/全不选/点选/行内点选(Mr.Think)
2016/10/29 Javascript
详解vue-router基本使用
2017/04/18 Javascript
详解bootstrap导航栏.nav与.navbar区别
2017/11/23 Javascript
jQuery实现模糊搜索功能的方法分析
2018/06/29 jQuery
node.js中事件触发器events的使用方法实例分析
2019/11/23 Javascript
Vue 根据条件判断van-tab的显示方式
2020/08/03 Javascript
[14:25]教你分分钟做大人:主宰(HEROS)
2014/12/08 DOTA
Python脚本实现自动发带图的微博
2016/04/27 Python
Python编程实现的图片识别功能示例
2017/08/03 Python
Python内存管理方式和垃圾回收算法解析
2017/11/11 Python
python中不能连接超时的问题及解决方法
2018/06/10 Python
Python Django2.0集成Celery4.1教程
2019/11/19 Python
如何使用html5与css3完成google涂鸦动画
2012/12/16 HTML / CSS
Giglio美国站:意大利奢侈品购物网
2018/02/10 全球购物
广州某公司软件工程师面试题
2014/12/22 面试题
机械专业应届生求职信
2013/09/21 职场文书
三分钟英语演讲稿
2014/04/24 职场文书
说好普通话圆梦你我他演讲稿
2014/09/21 职场文书
公务员年度考核登记表个人总结
2015/02/12 职场文书
董事长秘书岗位职责
2015/02/13 职场文书
Python中else的三种使用场景
2021/06/16 Python
Python之基础函数案例详解
2021/08/30 Python