微信小程序点击实现样式切换功能

普通的web开发可以通过JavaScript获取HTML的Dom结构,但是小程序不可以,小程序实现此功能的方式:数据绑定+data- 去更改标签类名。

微信小程序点击实现样式切换功能

step 1 给选定的标志 {{}} & data-num

此处只绑定了一个类名,也可以绑定N个类名。

 

  1. class='class1 class2 {{num==1?"active":""}}'
  2. <view class='oil_s' catchtap='changeOil'>
  3. <view class='{{num==1?"active":""}}' data-num='1'>92#汽油</view>
  4. <view class='{{num==2?"active":""}}' data-num='2'>95#汽油</view>
  5. <view class='{{num==3?"active":""}}' data-num='3'>0#汽油</view>

绑定一个事件 可以给外面的块绑定,也可以给每一个里边的view绑定,如下:

 

  1. <view class='oil_s' >
  2. <view class='{{num==1?"active":""}}' data-num='1' catchtap='changeOil'>92#汽油</view>
  3. <view class='{{num==2?"active":""}}' data-num='2' catchtap='changeOil'>95#汽油</view>
  4. <view class='{{num==3?"active":""}}' data-num='3' catchtap='changeOil'>0#汽油</view>
  5. </view>

唯一的区别是给事件传入的 e 不同。  绑定在外面的块的事件的e ,只有 target才会有dataset的值。  绑定给每一个小块的事件的e ,不管是 target还是currentTarget都会有dataset的值。 

 

e.target.dataset.num  step 2 写好初始值

一开始选定哪一个,就给判断的那个变量哪个值

 

  1. data: {
  2. num:1
  3. },

step 3 写好事件处理函数

 

  1. changeOil:function(e){
  2. console.log(e);
  3. this.setData({
  4. num:e.target.dataset.num
  5. })
  6. }

原理 是改变一下 用来判断的那个变量 num 的值而已。

他人的做法:

我用的类名active ,有的人会用cur ,【current的简写】  有人甚至总结出了三种方式:

 

  1. 1.通过修改类名 <view class="{{className}}"></view>
  2. 2.添加一个类名,覆盖前面的样式 <view class="helplist {{cur}}"></view>
  3. 3.修改行内样式,覆盖前面的样式 <view class="helplist" style="{{currentStyle}}"></view>

第二种方式跟我的一样,第三种方式最好不要使用,毕竟我们要做一个性能佳的小程序。  至此,完成。 

微信小程序点击实现样式切换功能


【本站声明】
  1、本站文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如果有侵权请立即联系。
  2、本网站不对文章中所涉及的内容真实性、准确性、可靠性负责,仅系客观性描述,如您需要了解该类商品/服务详细的资讯,请您直接与该类商品/服务的提供者联系。


KESION 科汛软件

KESION 科汛软件是国内领先的在线教育软件及私域社交电商软件服务提供商,长期专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。
公司核心产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化独立部署品牌网校和在线教育咨询等。

KESION 不断通过技术创新,提供产品和服务,助力企业向数字化转型,通过科技驱动商业革新,让商业变得更智慧!



▼点击进入科汛官网了解更多



热门标签
微信小程序 SaaS
上/下篇
换一换相关推荐
精选内容
热点精选