微信小程序内怎样动态绑定类名

这次给大家带来微信小程序内怎样动态绑定类名,微信小程序内怎样动态绑定类名的注意事项有哪些,下面就是实战案例,一起来看一下。

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

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

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

模块化

我们可以将一些公共的代码抽离成为一个单独的 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 块”

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

微信小程序:使用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分开写

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

微信小程序:

<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绑定事件的函数传参数时,可以把参数写在函数后面的括号里

<p @click=changeTab(1)>哈哈</p>

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

<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

相信看了本文案例你已经掌握了方法,更多精彩请关注编程之家网其它相关文章!

推荐阅读:

Angular中怎样调用第三方库

Angular ng-animate与ng-cookies如何在项目内使用

相关文章

概述 消息能力是小程序能力中的重要组成,我们为开发者提供了...
判断H5页面环境在微信中还是小程序中 用小程序提供的wx.mini...
wx.reLaunch和wx.navigateTo,wx.navigateTo的区别 2019-03-...
微信小程序如何从数组里取值_微信小程序 传值取值的几种方法...
H5项目接入微信授权登录,通过 UA 区分微信还是普通浏览器:...
微信小程序获取data-xx=&quot;&quot;属性的值,自定...