zoukankan      html  css  js  c++  java
  • 微信小程序如何像vue一样在动态绑定类名

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

     更新时间:2018年04月17日 14:08:44   

     
    这篇文章主要介绍了微信小程序如何像vue一样在动态绑定类名,文中给大家提到了vue与微信小程序的区别,需要的朋友可以参考下
     

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

    排行榜开发的时候,前三名的样式不同,其余的样式一样。但是都是通过同一元素来遍历的,当时卡了一下。后来发现有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 块”

     <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一样在动态绑定类名 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

  • 相关阅读:
    Codeforces 376A. Night at the Museum
    Assigning Workstations
    树的直径证明
    Frogger
    Circle
    HDU 1022 Train Problem I
    Argus
    树状数组总结
    C++ 容器(一):顺序容器简介
    C++ 输出缓冲区的管理
  • 原文地址:https://www.cnblogs.com/lguow/p/10115455.html
Copyright © 2011-2022 走看看