• 微信小程序:实现列表单选


     效果

    代码

     wxml

    1. <view class="all">
    2. <view class="item_all" wx:for="{{info}}" wx:key="index">
    3. <view class='position {{item.checked?"checked_parameter":""}}' data-id="{{item.employee_num}}" bindtap='selectcustomer'>
    4. <view class="vv_1">{{item.num_name}}view>
    5. view>
    6. view>
    7. view>

    wxss

    1. /* 列表 */
    2. .item_all {
    3. /* border: 1px solid black; */
    4. margin-bottom: 3%;
    5. width: 100%;
    6. }
    7. .position {
    8. display: flex;
    9. flex-direction: column;
    10. justify-content: center;
    11. height: 80px;
    12. border-radius: 10px;
    13. background-color: #fff;
    14. box-shadow: 2px 2px 2px gainsboro;
    15. }
    16. .vv_1 {
    17. margin-left: 5%;
    18. word-break: break-all;
    19. }
    20. /* 选中之后的样式设置 */
    21. .checked_parameter {
    22. background-color: #74bfe7;
    23. color: #fff;
    24. }

    js 

    1. const app = getApp()
    2. Page({
    3. data: {
    4. info: [{
    5. employee_num: 1001,
    6. employee_name: '张三',
    7. checked: false,
    8. num_name: '1001-张三'
    9. },
    10. {
    11. employee_num: 1002,
    12. employee_name: '李四',
    13. checked: false,
    14. num_name: '1002-李四'
    15. }, {
    16. employee_num: 1003,
    17. employee_name: '王五',
    18. checked: false,
    19. num_name: '1003-王五'
    20. }, {
    21. employee_num: 1004,
    22. employee_name: '赵六',
    23. checked: false,
    24. num_name: '1004-赵六'
    25. }
    26. ],
    27. parameterList: ''
    28. },
    29. // 参数点击响应事件
    30. selectcustomer: function (e) {
    31. var this_checked = e.currentTarget.dataset.id //获取对应的条目id
    32. var parameterList = this.data.info //获取Json数组
    33. console.log(this_checked)
    34. for (var i = 0; i < parameterList.length; i++) {
    35. if (parameterList[i].employee_num == this_checked) {
    36. parameterList[i].checked = true; //当前点击的位置为true即选中
    37. this.setData({
    38. parameterList:parameterList[i]
    39. })
    40. console.log('参数', this.data.parameterList)
    41. } else {
    42. parameterList[i].checked = false; //其他的位置为false
    43. }
    44. }
    45. this.setData({
    46. info:parameterList
    47. })
    48. },
    49. })

  • 相关阅读:
    thinkphp5实现多数据库连接
    管程的介绍
    从零开始用 Axios 请求后端接口
    [论文阅读笔记17]MAT: Motion-Aware Multi-Object Tracking
    2022数学建模国赛B题思路分析
    echarts如何画地图
    Python - 深度学习系列38 重塑实体识别5-预测并行化改造
    下载 Windows11 23H2 官方系统镜像
    redis-集群-1-主从复制:单台机器模拟主从复制,一主二从
    【置顶】QT的知识点以及代码汇总整理
  • 原文地址:https://blog.csdn.net/weixin_46001736/article/details/133698688