小程序实现选择题选择效果


Posted in Javascript onNovember 04, 2018

本文实例为大家分享了小程序实现选择题的显示方法,供大家参考,具体内容如下

下面是三张效果图:初始图,选项正确图,选项错误图。

小程序实现选择题选择效果小程序实现选择题选择效果小程序实现选择题选择效果

wxml代码:

<view class='selection'>
 <view class='{{view1}}' bindtap='view1Click' id='1'>a</view>
 <view class='{{view2}}' bindtap='view2Click' id='2'>b</view>
 <view class='{{view3}}' bindtap='view3Click' id='3'>c</view>
 <view class='{{view4}}' bindtap='view4Click' id='4'>d</view>
</view>

js代码:

Page({ 
 
 /** 
  * 页面的初始数据 
  */ 
 data: { 
  view1: 'selection1', 
  view2: 'selection1', 
  view3: 'selection1', 
  view4: 'selection1', 
  // 默认答案为2,后台会给的 
  key: 2, 
  // 选项是否被点击 
  isSelect: false 
 }, 
 
 view1Click: function(e) { 
  var select = e.target.id 
  // 选项没被选择时将执行 
  if (!this.data.isSelect) { 
   // 将选项设置为“已被选择” 
   this.setData({ 
    isSelect: true 
   }) 
   // 注意!此处必须是'=='而不是'=' 
   if (select == this.data.key) { 
    this.setData({ 
     view1: 'selection2' 
    }) 
   } else { 
    this.setData({ 
     view1: 'selection3' 
    }) 
    // 将正确选项显示出来 
    this.showAnswer(this.data.key) 
   } 
 
  } 
 }, 
 view2Click: function(e) { 
  var select = e.target.id 
  // 选项没被选择时将执行 
  if (!this.data.isSelect) { 
   this.setData({ 
    isSelect: true 
   }) 
   // 注意!此处必须是'=='而不是'=' 
   if (select == this.data.key) { 
    this.setData({ 
     view2: 'selection2' 
    }) 
   } else { 
    this.setData({ 
     view2: 'selection3' 
    }) 
    // 将正确选项显示出来 
    this.showAnswer(this.data.key) 
   } 
 
  } 
 }, 
 view3Click: function(e) { 
  var select = e.target.id 
  // 选项没被选择时将执行 
  if (!this.data.isSelect) { 
   this.setData({ 
    isSelect: true 
   }) 
   // 注意!此处必须是'=='而不是'=' 
   if (select == this.data.key) { 
    this.setData({ 
     view3: 'selection2' 
    }) 
   } else { 
    this.setData({ 
     view3: 'selection3' 
    }) 
    // 将正确选项显示出来 
    this.showAnswer(this.data.key) 
   } 
 
  } 
 }, 
 view4Click: function(e) { 
  var select = e.target.id 
  // 选项没被选择时将执行 
  if (!this.data.isSelect) { 
   this.setData({ 
    isSelect: true 
   }) 
   // 注意!此处必须是'=='而不是'=' 
   if (select == this.data.key) { 
    this.setData({ 
     view4: 'selection2' 
    }) 
   } else { 
    this.setData({ 
     view4: 'selection3' 
    }) 
    // 将正确选项显示出来 
    this.showAnswer(this.data.key) 
   } 
 
  } 
 }, 
 showAnswer: function(key) { 
  // 通过swith语句判断正确答案,从而显示正确选项 
  switch (key) { 
   case 1: 
    this.setData({ 
     view1: 'selection2' 
    }) 
    break; 
   case 2: 
    this.setData({ 
     view2: 'selection2' 
    }) 
    break; 
   case 3: 
    this.setData({ 
     view3: 'selection2' 
    }) 
    break; 
   default: 
    this.setData({ 
     view4: 'selection2' 
    }) 
  } 
 } 
})

wxss代码:

.selection1{
width: 400rpx;
height: 150rpx;
background-color: grey;

display: flex;
flex-direction: column;
justify-content: space-around;
align-items: center;
}
.selection2{
width: 400rpx;
height: 150rpx;
background-color: blue;
display: flex;
flex-direction: column;
justify-content: space-around;
align-items: center;
}
.selection3{
width: 400rpx;
height: 150rpx;
background-color: red;
display: flex;
flex-direction: column;
justify-content: space-around;
align-items: center;
}
.selection{
width: 750rpx;
height: 800rpx;
display: flex;
flex-direction: column;
justify-content: space-around;
align-items: center;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript入门学习资料收集整理篇
Jul 06 Javascript
jquery对表单操作2
Apr 06 Javascript
js 弹出框只弹一次(二次修改之后的)
Nov 26 Javascript
jquery解析xml字符串示例分享
Mar 25 Javascript
JavaScript实现鼠标点击后层展开效果的方法
May 13 Javascript
JavaScript实现图片滑动切换的代码示例分享
Mar 06 Javascript
Javascript的表单与验证-非空验证
Mar 18 Javascript
jQuery实现的兼容性浮动层示例
Aug 02 Javascript
js实现四舍五入完全保留两位小数的方法
Aug 02 Javascript
JavaScript输入框字数实时统计更新
Jun 17 Javascript
JavaScript动态生成表格的示例
Nov 02 Javascript
vue 使用class创建和清除水印的示例代码
Dec 25 Vue.js
小程序实现单选多选功能
Nov 04 #Javascript
Vuex的基本概念、项目搭建以及入坑点
Nov 04 #Javascript
微信小程序实现登录注册tab切换效果
Dec 29 #Javascript
原生js实现淘宝放大镜效果
Oct 28 #Javascript
微信小程序如何获取手机验证码
Nov 04 #Javascript
微信小程序实现弹出层效果
May 26 #Javascript
微信小程序实现预览图片功能
Oct 22 #Javascript
You might like
IIS7.X配置PHP运行环境小结
2011/06/09 PHP
分享一个超好用的php header下载函数
2014/01/31 PHP
使用PHP接受文件并获得其后缀名的方法
2015/08/05 PHP
jquery1.5.1中根据元素ID获取元素对象的代码
2011/04/02 Javascript
关于js类的定义
2011/06/28 Javascript
Ajax局部更新导致JS事件重复触发问题的解决方法
2014/10/14 Javascript
Javascript无参数和有参数类继承问题解决方法
2015/03/02 Javascript
JS延时提示框实现方法详解
2015/11/26 Javascript
jQuery实现查找最近父节点的方法
2016/06/23 Javascript
js删除Array数组中指定元素的两种方法
2016/08/03 Javascript
解决wx.onMenuShareTimeline出现的问题
2016/08/16 Javascript
Laravel中常见的错误与解决方法小结
2016/08/30 Javascript
详细讲解JavaScript中的this绑定
2016/10/10 Javascript
详解用webpack把我们的业务模块分开打包的方法
2017/07/20 Javascript
Vue中如何实现proxy代理
2018/04/20 Javascript
关于layui表单中按钮自动提交的解决方法
2019/09/09 Javascript
[35:29]Secret vs VG 2018国际邀请赛淘汰赛BO3 第三场 8.23
2018/08/24 DOTA
python操作CouchDB的方法
2014/10/08 Python
python实现中文分词FMM算法实例
2015/07/10 Python
Python 中的 else详解
2016/04/23 Python
Python中Unittest框架的具体使用
2019/08/27 Python
python中对_init_的理解及实例解析
2019/10/11 Python
使用python实现希尔、计数、基数基础排序的代码
2019/12/25 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
OpenCV Python实现拼图小游戏
2020/03/23 Python
用python查找统一局域网下ip对应的mac地址
2021/01/13 Python
详解使用scrapy进行模拟登陆三种方式
2021/02/21 Python
丝芙兰法国官网:SEPHORA法国
2016/09/01 全球购物
天猫精选:上天猫,就够了
2016/09/21 全球购物
香港网上花店:FlowerAdvisor香港
2019/05/30 全球购物
IT工程师岗位职责
2014/07/04 职场文书
2014年个人债务授权委托书范本
2014/09/22 职场文书
2014年扶贫工作总结
2014/11/18 职场文书
python使用pygame创建精灵Sprite
2021/04/06 Python
JavaScript实现简单计时器
2021/06/22 Javascript
Sql Server之数据类型详解
2022/02/28 SQL Server