vue根据条件不同显示不同按钮的操作


Posted in Javascript onAugust 04, 2020

我就废话不多说了,大家还是直接看代码吧~

<template slot-scope="scope">
 <el-button v-if="scope.row.isDeleted === 0" @click="lowerShelf(scope.row.id)" size="mini" type="primary" plain>下架</el-button>
 <el-button v-else size="mini" type="primary" plain>已下架</el-button>
</template>

补充知识:vue 过滤器之根据不同的类型渲染不同的字段

本文旨在分享如何利用vue过滤器,实现简单、高效的对同一个字段不同的字段值,渲染出不同的内容。

实际场景中我们可能会遇到后端在传给我们的数据中,某一个字段为type,type的值有1、2、3、4、5、6等,

1-6分别对应的是,苹果、梨、葡萄、芒果、香蕉、百香果。如何通过写最少的代码就能实现将他们一一对应起来呢?下面将一一介绍:

<ul>
 <li v-for="(d,index) in value" :key="index">
 {{d.type| filterType}}
 </li>
 </ul>

首先最初级的做法就是:在拿到数据后我们可能会用if/else来判断,如下所示:

filters: {
 filterType: function(val) {
 // 1、苹果 2、梨 3、葡萄 4、芒果 5、香蕉 6、百香果
 if (val ==== 1) {
 return '苹果'
 } else if (val ==== 2) {
 return '梨'
 } else if (val ==== 3) {
 return '葡萄'
 } else if (val === 4) {
 return '芒果'
 } else if (val === 5) {
 return '香蕉'
 } else if (val === 6) {
 return '百香果'
 } else {
 return '未知类型'
 }
 }
 }

这种写法是可以实现需求的,但是随着type的值逐渐增多,else if 的代码块会越来越臃肿,这种写法带来的后果就是可读性越来越差,且写法也不优雅,如何优化这点呢?我们可以使用switch:

filters: {
 filterType: function(val) {
 // 1、苹果 2、梨 3、葡萄 4、芒果 5、香蕉 6、百香果
 switch (val) {
 case 1:
  return '苹果'
  break;
 case 2:
  return '梨'
  break;
 case 3:
  return '葡萄'
  break;
 case 4:
  return '芒果'
  break;
 case 5:
  return '香蕉'
  break;
 case 6:
  return '百香果'
  break;
 default:
  return '未知类型'
 }
 }
 }

这样写比if/else 的写法可读性提高了不少,但是代码量还是挺多的,一个小功能用了这么多代码,实在是不能忍受,那怎么减少代码量呢?请往下看。。

filters: {
 filterType: function(val) {
 // 1、苹果 2、梨 3、葡萄 4、芒果 5、香蕉 6、百香果
 var typeArr = ['苹果', '梨' , '葡萄', '芒果', '香蕉', '百香果'];
 return typeArr[val-1];
 }
}

我们可以把存在的类型值放在数组里面,通过传入的type作为数组的下表,即可取到对应的值。这里要特别要提示一下,若type的值是从1开始,那传入的val就要减一,数组的下标是从0开始。

可以看到,这样写我们的确是少写了很多代码,但是有个问题,上面的方法只适用于1-n这种有顺序的正整数类型,假如type为-1,1,2,3,23 这种无序的情况就不适用了,怎么解决呢?且看下面

filters: {
 filterType: function(val) {
 // -1、苹果 2、梨 6、葡萄 8、芒果 13、香蕉 156、百香果
 let typeArr = [{"-1": "苹果"},{"2": "梨"},{"6": "葡萄"},{"8": "芒果"},{"13": "香蕉"},{"156": "百香果"}];
 let result = originTypeArr.filter((item) => Object.keys(item)[0] == row.type);
 return result.length > 0 ? result[0][row.type] : '未知类型';
 }
}

上面这个写法将type值作为对象的键值,通过filtes和Object.keys拿到数组中所有的键值,判断传入的val 是否和遍历的key值相等,来取到对应的value值

最后两种方法具体使用看具体场景,若是连续的正整数,可以直接使用第二种方法,若是需要扩展性强的,直接使用最后一种。

如有更好的写法,欢迎交流!!

以上这篇vue根据条件不同显示不同按钮的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery控制左右箭头滚动图片列表的实例
May 20 Javascript
javascript实现下班倒计时效果的方法(可桌面通知)
Jul 10 Javascript
JavaScript实现非常简单实用的下拉菜单效果
Aug 27 Javascript
去除html代码里面的script正则方法
May 19 Javascript
表单元素值获取方式js及java方式的简单实例
Oct 15 Javascript
JS失效 提示HTML1114: (UNICODE 字节顺序标记)的代码页 utf-8 覆盖(META 标记)的冲突的代码页 utf-8
Jun 23 Javascript
jQuery EasyUI开发技巧总结
Sep 26 jQuery
Node.js readline模块与util模块的使用
Mar 01 Javascript
轻量级JS Cookie插件js-cookie的使用方法
Mar 22 Javascript
vue下拉列表功能实例代码
Apr 08 Javascript
jQuery中DOM操作原则实例分析
Aug 01 jQuery
在vue中使用eslint,配合vscode的操作
Nov 09 Javascript
如何在Vue.JS中使用图标组件
Aug 04 #Javascript
如何构建 vue-ssr 项目的方法步骤
Aug 04 #Javascript
vue-quill-editor的使用及个性化定制操作
Aug 04 #Javascript
vue 添加和编辑用同一个表单,el-form表单提交后清空表单数据操作
Aug 03 #Javascript
浅谈vue中get请求解决传输数据是数组格式的问题
Aug 03 #Javascript
VUE使用axios调用后台API接口的方法
Aug 03 #Javascript
vue cli3.0打包上线静态资源找不到路径的解决操作
Aug 03 #Javascript
You might like
smarty静态实验表明,网络上是错的~呵呵
2006/11/25 PHP
PHP中用header图片地址 简单隐藏图片源地址
2008/04/09 PHP
PHP时间戳 strtotime()使用方法和技巧
2013/10/29 PHP
php 根据url自动生成缩略图并处理高并发问题
2014/01/23 PHP
php中mysql连接和基本操作代码(快速测试使用,简单方便)
2014/04/25 PHP
1亿条数据如何分表100张到Mysql数据库中(PHP)
2015/07/29 PHP
ThinkPHP模板循环输出Volist标签用法实例详解
2016/03/23 PHP
php获取指定数量随机字符串的方法
2017/02/06 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
2018/09/29 PHP
使用javascript访问XML数据的实例
2006/12/27 Javascript
jquery 3D 标签云示例代码
2014/06/12 Javascript
基于Node.js实现nodemailer邮件发送
2016/01/26 Javascript
浅谈AngularJS中ng-class的使用方法
2016/11/11 Javascript
基于jQuery实现Accordion手风琴自定义插件
2020/10/13 Javascript
bootstrap table 表格中增加下拉菜单末行出现滚动条的快速解决方法
2017/01/05 Javascript
js eval函数使用,js对象和字符串互转实例
2017/03/06 Javascript
NodeJS 实现手机短信验证模块阿里大于功能
2017/06/19 NodeJs
详解vue-router 路由元信息
2017/09/13 Javascript
Vue二次封装axios为插件使用详解
2018/05/21 Javascript
详解Vue.directive 自定义指令
2019/03/27 Javascript
构建大型 Vue.js 项目的10条建议(小结)
2019/11/14 Javascript
viewer.js实现图片预览功能
2020/06/24 Javascript
JavaScript实现图片合成下载的示例
2020/11/19 Javascript
Python bsddb模块操作Berkeley DB数据库介绍
2015/04/08 Python
python递归计算N!的方法
2015/05/05 Python
python高手之路python处理excel文件(方法汇总)
2016/01/07 Python
Python返回数组/List长度的实例
2018/06/23 Python
Python手绘可视化工具cutecharts使用实例
2019/12/05 Python
计算Python Numpy向量之间的欧氏距离实例
2020/05/22 Python
python+openCV对视频进行截取的实现
2020/11/27 Python
中国宠物用品商城:E宠商城
2016/08/27 全球购物
欧洲品牌瓷器餐具网上商店:Porzellantreff.de
2018/04/04 全球购物
北京某公司的.net笔试题
2014/03/20 面试题
公务员平时考核实施方案
2014/03/11 职场文书
公司承诺书范文
2014/05/19 职场文书
Python OpenCV实现图像模板匹配详解
2022/04/07 Python