微信小程序如何像vue一样在动态绑定类名


Posted in Javascript onApril 17, 2018

小程序 开发中遇到这样一个问题...

排行榜开发的时候,前三名的样式不同,其余的样式一样。但是都是通过同一元素来遍历的,当时卡了一下。后来发现有module模块化这一概念,于是查了下api,一下子就做出来了。

微信小程序如何像vue一样在动态绑定类名 

就是不同名次上边的样式根据实际情况展示效果。

模块化

我们可以将一些公共的代码抽离成为一个单独的 js 文件,作为一个模块。模块只有通过 module.exports 或者 exports 才能对外暴露接口。

通俗的将就是自身独立,作用域只作用于该模块,与js互不影响。

主要代码

module部分

<wxs module="rank">
 var indexof = function(index){
 switch(index){
 case 0:
 return 'first-price';
 break;
 case 1: 
 return 'second-price';
 break;
 case 2: 
 return 'third-price';
 break;
 }
 };
 module.exports.style = indexof;
 </wxs>

view

<view class="weui-badge {{rank.style(index)}}">{{index + 1}}</view>

补充:

vue与微信小程序的一些区别

一.条件渲染

vue:使用v-if指令,v-else表示v-if的else块,v-else-if表示v-if 的“else-if 块”

<div v-if="type === 'A'">
  A
 </div>
 <div v-else-if="type === 'B'">
  B
 </div>
 <div v-else-if="type === 'C'">
  C
 </div>
 <div v-else>
  Not A/B/C
 </div>

微信小程序:使用wx:if,wx:else表示wx:if的else块,wx:elif表示wx:if的"else-if"块

<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view>

二.显示隐藏元素

VUE:v-show="..."

微信小程序:hidden="{{...}}"

三.绑定class

vue:全用v-bind,或者简写为:bind,和本有的class分开写

<div class="test" v-bind:class="{ active: isActive }"></div>

微信小程序:

<view class="test {{isActive ? 'active':'' }}"></view>

四.事件处理

VUE:使用v-on:event绑定事件,或者使用@event绑定事件

<button v-on:click="counter += 1">Add 1</button>
<button v-on:click.stop="counter+=1">Add1</button> //阻止事件冒泡

微信小程序:全用bindtap(bind+event),或者catchtap(catch+event)绑定事件

<button bindtap="clickMe">点击我</button>
<button catchtap="clickMe">点击我</button> //阻止事件冒泡

五.绑定值

VUE:vue动态绑定一个变量的值为元素的某个属性的时候,会在变量前面加上冒号:,例:<img :src="imgSrc"/>

微信小程序:绑定某个变量的值为元素属性时,会用两个大括号括起来。例:<image src="{{imgSrc}}"></image>

六.绑定事件传参

VUE:vue绑定事件的函数传参数时,可以把参数写在函数后面的括号里

<div @click="changeTab(1)">哈哈</div>

微信小程序:微信小程序的事件我试过只能传函数名,至于函数值,可以绑定到元素中,在函数中获取

<view data-tab="1" catchtap="changeTab">哈哈</view>

js:

changeTab(e){
  var _tab = e.currentTarget.dataset.tab; 
}

七.设置值

VUE:设置test的值可以用,this.test = true;获取test的值可以用this.test.

微信小程序:设置test的值要用this.setData({test:true});获取test的值用this.data.test

总结

以上所述是小编给大家介绍的微信小程序如何像vue一样在动态绑定类名 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
硬盘浏览程序,保存成网页格式便可使用
Dec 03 Javascript
深入认识JavaScript中的函数
Jan 22 Javascript
JavaScript设置IFrame高度自适应(兼容各主流浏览器)
Jun 05 Javascript
jQuery判断checkbox是否选中的3种方法
Aug 12 Javascript
JavaScript实现DIV层拖动及动态增加新层的方法
May 12 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
Mar 01 Javascript
jQuery基于扩展实现的倒计时效果
May 14 Javascript
Angular.js 实现数字转换汉字实例代码
Jul 14 Javascript
javascript表达式和运算符详解
Feb 07 Javascript
vue组件 $children,$refs,$parent的使用详解
Jul 31 Javascript
Javascript实现鼠标点击冒泡特效
Dec 24 Javascript
vue+echarts+datav大屏数据展示及实现中国地图省市县下钻功能
Nov 16 Javascript
Angular数据绑定机制原理
Apr 17 #Javascript
基于vue-ssr的静态网站生成器VuePress 初体验
Apr 17 #Javascript
jQuery实现使用sort方法对json数据排序的方法
Apr 17 #jQuery
jQuery+datatables插件实现ajax加载数据与增删改查功能示例
Apr 17 #jQuery
jQuery实现带右侧索引功能的通讯录示例【附源码下载】
Apr 17 #jQuery
Angular 容器部署的方法
Apr 17 #Javascript
bootstrap中日历范围选择插件daterangepicker的使用详解
Apr 17 #Javascript
You might like
php的urlencode()URL编码函数浅析
2011/08/09 PHP
深入解析PHP的引用计数机制
2013/06/14 PHP
php时区转换转换函数
2014/01/07 PHP
PHP中preg_match正则匹配中的/u、/i、/s含义
2015/04/17 PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
2015/07/31 PHP
Js 本页面传值实现代码
2009/05/17 Javascript
JavaScript prototype属性使用说明
2010/05/13 Javascript
javascript权威指南 学习笔记之变量作用域分享
2011/09/28 Javascript
js传参数受特殊字符影响错误的解决方法
2013/10/21 Javascript
JS实现点击链接取消跳转效果的方法
2014/01/24 Javascript
javascript设计模式之解释器模式详解
2014/06/05 Javascript
jQuery Masonry瀑布流插件使用详解
2014/11/17 Javascript
JQuery自适应窗口大小导航菜单附源码下载
2015/09/01 Javascript
javascript中的 object 和 function小结
2016/08/14 Javascript
JS Testing Properties 判断属性是否在对象里的方法
2017/10/01 Javascript
Vuex的actions属性的具体使用
2019/04/14 Javascript
移动端手指操控左右滑动的菜单
2019/09/08 Javascript
js中switch语句的学习笔记
2020/03/25 Javascript
vue-cli脚手架的.babelrc文件用法说明
2020/09/11 Javascript
50行代码实现贪吃蛇(具体思路及代码)
2013/04/27 Python
使用Nginx+uWsgi实现Python的Django框架站点动静分离
2016/03/21 Python
详解Python在七牛云平台的应用(一)
2017/12/05 Python
python range()函数取反序遍历sequence的方法
2018/06/25 Python
numpy matrix和array的乘和加实例
2018/06/28 Python
Python3中bytes类型转换为str类型
2018/09/27 Python
Python基于BeautifulSoup和requests实现的爬虫功能示例
2019/08/02 Python
Django为窗体加上防机器人的验证码功能过程解析
2019/08/14 Python
Linux下通过python获取本机ip方法示例
2019/09/06 Python
详解Windows下PyCharm安装Numpy包及无法安装问题解决方案
2020/06/18 Python
Python爬虫分析微博热搜关键词的实现代码
2021/02/22 Python
CSS3实现自定义Checkbox特效实例代码
2017/04/24 HTML / CSS
公司董事长职责
2013/12/12 职场文书
教师师德师风整改措施
2014/10/24 职场文书
2014年学习委员工作总结
2014/11/14 职场文书
实习科室评语
2015/01/04 职场文书
win11开机发生死循环重启怎么办?win11开机发生死循环重启解决方法
2022/08/05 数码科技