Vue+elementUI的this.$refs.对象名.方法名的理解

最近用到了Vue+elementUI,原先觉得是坑多,后来发现是自己理解不到位。elementUI为很多控件都提供了事件(方法)
现在我们就说说这些方法

例一:如下面这段代码中,select控件里面我绑定了一个change事件,该事件是elementUI封装好的,其实这些封装好的事件就相当于是一个接口,而我们的selectStatusChange,相当于去实现这个接口的一个类的对象,至于该接口做什么,elementUI给我们定义了这个规范(规定就是当改变控件的时候触发该事件:这是该接口(即@change)的作用),然后接口里具体的代码实现的需要我们自己去写。
其实说这么多就是像改变一下我对这控件事件的理解思维。以前只觉得就是个方法,我定义,调用实现就OK了。现在不是这样,他们也都是一个个的接口或者实现好的方法,我们定义的方法相当于是一个对象去实现或者覆盖它们。

<el-select v-model="selectState" placeholder="状态" @change="selectStatusChange"
                           size="small">
                    <el-option v-for="item in opentions" :label="item.label" :value="item.value"
                               :key="item.key"></el-option>
                </el-select>

案例二:以前根本看不懂这么写是什么意思:

this.$refs.tree.getCheckedKeys());

其实上面的方法就是已经封装好的,直接调用即可,this,代表在当前vue里,$refs代表一个引用(可以把它近似看成一个包名,)然后tree就是我们的el-tree的ref,可以理解为是该控件的一个对象,然后我们可以通过对象调用方法。但是如果按照案例一那样写就不对了
即:

 <el-tree

                  ref="tree"
                  :data="treeList"
                  :props="defaultProps"
                  @node-click="handleNodeClick"
                  @getCheckedKeys()="function"
                  show-checkbox=true
                  node-key="id"
                >
        </el-tree>

上面这样写其实本质上就是我们自己定义的一个方法,覆盖掉了,原先elementUI帮我们封装好的方法,我们调用的时候就是我们自己的了,我们可以根据我们所需要的自定义实现该方法。如果要想调用原生态的方法就用this.$refs.tree.getCheckedKeys());
这种方式。但是也不见得所有的事件都有原生态的方法,比如有些事件只是定义了一个接口,具体的实现还得我们自己来,比如我们的button点击事件,我们的自己实现想要的功能,因为需求是不同的。如果你只写写成这样this.$refs.tree.getCheckedKeys());那我也没有试过会怎么样,会调用什么方法。总之可能你调用了一个方法,但是你没有任何的实现,那这就没有任何的意义了。

注:以后写代码,看代码,或者用新的控件,还是要用面向对象的思维去理解,那样会看到框架后的本质(果真是万物皆对象),受益匪浅啊,非常感谢孟学长,给我解答了好多疑惑。

Vue.js中使用Element UI实现省市二级联动功能通常会涉及数据管理、模板渲染和事件监听。以下是基本的操作步骤和代码示例: **步骤1**: 安装必要的依赖 首先确保已经在项目中安装了Vue和Element UI。如果没有安装,可以使用npm或yarn安装: ```bash npm install vue @element-ui/core # 或者 yarn add vue @element-ui/core ``` **步骤2**: 创建组件结构** 创建一个为`ProvincesCity.vue`的组件,用于展示省市联动选择器: ```html <template> <el-form-item label="省市区"> <el-cascader v-model="provinceCity" :options="provinces" placeholder="请选择省份" :props="{ options: 'cities', lazy: true }" ></el-cascader> </el-form-item> </template> <script> export default { data() { return { provinces: [], // 存放省级数据 cities: {}, // 存放市级数据,是一个映射对象 { 省份: [城市列表] } provinceCity: '', // 当前选中的省市区 }; }, // ...其他生命周期钩子和计算属性 }; </script> ``` **步骤3**: 初始化数据** 在组件的`created`或`mounted`钩子中,加载省级数据,并根据省级数据动态生成市级数据: ```js created() { this.loadProvinces(); // 加载省级数据 }, methods: { loadProvinces() { // 这里假设你有一个接口获取省级数据 axios.get('/api/provinces').then(response => { const provinces = response.data; // 构建省市映射 provinces.forEach(province => { this.cities[province.id] = province.children || []; }); this.provinces = provinces; }); }, // 可能还需要一个加载市级数据的方法,当选择省份时触发 loadChildren(cityId) { // 调用另一个接口,传递cityId获取对应城市的列表 axios.get(`/api/cities/${cityId}`).then(response => { this.cities[cityId].push(...response.data); }); }, }, computed: { // 如果有级联的数据量很大,也可以通过v-model绑定的值来懒加载 filteredCities() { return this.cities[this.provinces.find(p => p.id === this.$refs.cascader.value)[0]]; }, }, // ... ``` **步骤4**: 添加事件监听** 为了实现联动效果,需要给级联选择器添加`change`事件监听,当用户选择省级数据时更新市级数据并清除当前选中的城市列表: ```html <template> <!--...--> <el-cascader ref="cascader" <!--...--> ></el-cascader> </template> <script> // ... methods: { // ... loadChildren, onProvinceChange(province) { this.provinceCity = province.join('/'); this.loadChildren(province[0]); // 仅针对首次选择省份 this.$refs.cascader.clearSelections(); }, }, watch: { provinces(newProvinces) { if (newProvinces.length > 0) { this.onProvinceChange(newProvinces[0]); } }, }, // ... </script> ``` 现在当你在页面上使用这个`ProvincesCity`组件时,选择省份时,城市选项将根据所选省份动态加载。 **相关问题--:** 1. Vue如何处理异步数据并在组件间通信? 2. Element UI的级联选择器是如何实现懒加载的? 3. 如何优化这种联动效果,提高性能?
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值