xml
<view class="segmentedControl">
    <!-- 循环遍历 -->
    <block wx:for="{{radioValues}}">
        <text data-index="{{index}}" bindtap="indexChanged" class="{{clazz[index]}}">{{item.value}}</text>
    </block>
</view>
 
css
/*LXSegmentedControl容器*/
.segmentedControl {
    /*水平居中*/
    margin: 30px auto;
    /*边框为2px 主色调为蓝*/
    border: 2px solid #39f;
    /*圆角6px*/
    border-radius: 6px;
    /*控件宽度*/
    width: 240px;
    /*控件高度*/
    height: 30px;
}
 
/*普通文本*/
.segmentedControl text {
    /*水平排列*/
    float: left;
    /*宽度为控件宽度的1/3 再减去2px的右边框*/
    width: 78px;
    /*字体大小*/
    font-size: 14px;
    /*主色调*/
    color: #39f;
    /*行高,与控件高度相等*/
    line-height: 30px;
    /*文本水平居中*/
    text-align: center;
    /*右边距*/
    border-right: 2px solid #39f;
}
 
/*选中状态文本*/
.segmentedControl text.selected {
    /*同主色调*/
   
    /*前景色为白色*/
    color: white;
}
 
/*最后一个分组按钮*/
.segmentedControl text.last {
    /*不必右边框*/
    border-right: 0;
    /*高度也不必减少2px,就是控件高度的1/3*/
    width: 80px;
}
 
 
js
Page({
    data: {
        radioValues: [
            {'value': '男','selected': false},
            {'value': '女','selected': true},
            {'value': '保密','selected': false},
        ],
        clazz: []
    },
    indexChanged: function(e){
        // 点中的是组中第个元素
        var index = e.target.dataset.index;
        // 读取原始的数组
        var radioValues = this.data.radioValues;
        for (var i = 0; i < radioValues.length; i++){
            // 全部改为非选中
            radioValues[i].selected = false;
            // 当前那个改为选中
            radioValues[index].selected = true;
        }
        // 写回数据
        this.setData({
            radioValues: radioValues
        });
        // clazz状态
        this.clazzStatus();
    },
    onLoad: function(){
        // onLoad 比 onReady 更早调用,后者为选中时屏幕闪动一下
        this.clazzStatus();
    },
    clazzStatus: function(){
        /* 此方法分别被加载时调用,点击某段时调用 */
        // class样式表如"selected last","selected"
        var clazz = [];
        // 参照数据源
        var radioValues = this.data.radioValues;
        for (var i = 0; i < radioValues.length; i++){
            // 默认为空串,即普通按钮
            var cls = '';
            // 高亮,追回selected
            if (radioValues[i].selected) {
                cls += 'selected ';
            }
            // 最后个元素, 追加last
            if (i == radioValues.length - 1) {
                cls += 'last ';
            }
            //去掉尾部空格
            cls = cls.replace(/(\s*$)/g,'');
            clazz[i] = cls;
        }
        // 写回数据
        this.setData({
            clazz: clazz
        });
    }
})
 
 
/*普通文本*/
.segmentedControl text {
    /*水平排列*/
    float: left;
    /*宽度为控件宽度的1/3 再减去2px的右边框*/
    width: 78px;
    /*字体大小*/
    font-size: 14px;
    /*主色调*/
    color: #39f;
    /*行高,与控件高度相等*/
    line-height: 30px;
    /*文本水平居中*/
    text-align: center;
    /*右边距*/
    border-right: 2px solid #39f;
}
 
/*选中状态文本*/
.segmentedControl text.selected {
    /*同主色调*/
   
    /*前景色为白色*/
    color: white;
}
 
/*最后一个分组按钮*/
.segmentedControl text.last {
    /*不必右边框*/
    border-right: 0;
    /*高度也不必减少2px,就是控件高度的1/3*/
    width: 80px;
}

segmentController的更多相关文章

  1. 函数响应式编程及ReactiveObjC学习笔记 (四)

    今天我们继续看其他的类别 UIImagePickerController+RACSignalSupport.h #import <UIKit/UIKit.h> @class RACDele ...

  2. ios 点餐系统

    这个程序的主要界面就是一个TabBarController.总共三个标签,第一个是所有的可点的菜,第二个是已点的菜,第三个是可以留言或者查看所有留言. 下面是第一个页面: 右上角的i按钮是添加新菜,每 ...

  3. ios之UIToolBar

    toolbar除了可以和navigationController一起用之外,也可以独立用到view里.工具栏UIToolbar – 一般显示在底部,用于提供一组选项,让用户执行一些功能,而并非用于在完 ...

  4. 第三方MBXPageViewController的使用和注意事项

    GitHub的地址: https://github.com/Moblox/MBXPageViewController 介绍SegmentController的使用: - (void)createSeg ...

随机推荐

  1. android 开发 我的高德地图代码例子

    下载高德地图依赖库和相关注册方式,请查看高德开发者网站:http://lbs.amap.com/api/android-sdk/summary  点击打开链接 高德地图坐标拾取器:http://lbs ...

  2. python批量处理文件夹中文件的问题

    用os模块读取文件夹中文件 原来的代码: import osfrom scipy.misc import imread filenames=os.listdir(r'./unprocess')for ...

  3. LevelDB源码分析-TableBuilder生成sstable

    TableBuilder生成sstable(include/table_builder.h table/table_builder.cc) LevelDB使用TableBuilder来构建sstabl ...

  4. funny故事

    name1 = input('请输入一个名字:') name2 = input('请输入一个名字:') vehicle = input('请输入一种车子:') print('\n上近代史的{}刚下课, ...

  5. Beta冲刺——第二天

    beat冲刺:第二天 各个成员今日完成的任务 成员 冯晓.马思远 彭辉.王爽 吴琼.郝延婷 今日完成任务 ·管理员功能模块的代码规范与测试 ·网站的前端调整 ·代码规范 ·系统管理模块功能测试 ·博客 ...

  6. 《深入理解JAVA虚拟机》----------第二章 JAVA内存区域与内存溢出异常,笔记(下)

    2. HotSpot虚拟机对象探秘 2.1 对象的创建 虚拟机遇到一条New指令时,首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初 ...

  7. sessionStorage实现note的功能

    功能图如图所示: 文本域中输入点击保存后的结果如图所示: 点击读取后的结果图: 选择山羊对应的按钮进行修改并点击保存后的结果: 选择山羊养对应的单选按钮进行删除操作后的结果图: 点击清空后的结果: 源 ...

  8. 项目(二)DNS解析——配置域名服务器

    NDS服务器常见种类有:缓存域名服务器.主域名服务器.从域名服务器.DNS服务器查询方法有两种:递归查询和迭代查询.其中,递归查询是DNS服务器在本地通过缓存.本地映射.记录本得到结果,而迭代查询是D ...

  9. 大数据入门到精通6---spark rdd reduce by key 的使用方法

    1.前期数据准备(同之前的章节) val collegesRdd= sc.textFile("/user/hdfs/CollegeNavigator.csv")val header ...

  10. dagScheduler

    由一个action动作触发sparkcontext的runjob,再由此触发dagScheduler.runJob,然后触发submitJob,封装一个JobSubmitted放入一个队列.然后再通过 ...