selectAll—part II

本文介绍了一个使用jQuery实现的全选功能。通过监听全选框的状态改变来控制多个复选框的选择状态,并且当部分复选框被手动更改状态时能够自动更新全选框的状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前写过一个全选的,以下是从
http://blog.youkuaiyun.com/fcc0429/article/details/74931807
摘抄的布局;

<div id="formdiv">
    <input type="checkbox" name="checkoption">篮球<p>
    <input type="checkbox" name="checkoption">足球
    <p>
        <input type="checkbox" name="checkoption">网球
    <p>
        <input type="checkbox" name="checkoption">台球
    <p>
        <input type="checkbox" id="selectAll">
        <label for="selectAll">全选</label>
</div>

这次使用jquery来写

$(
        $inputItem = $("input[name='checkoption']"),
        $selectAll = $("#selectAll"),
        $selectAll.click(function () {
            $inputItem.each(function () {
                $(this).prop("checked", $selectAll.prop("checked"))
            })
        }),
        $("#formdiv").delegate($inputItem, "click", function () {
            $inputItem.each(function () {        $inputChecked=$("input[name='checkoption']:checked").length;
                if($inputChecked===$inputItem.length){
                    $selectAll.prop("checked", true)
                }
                else {
                    $selectAll.prop("checked", false)
                }
            })
        })
    )

这里用input.cheked.length用的很好;
就是在想,以上代码是否有什么性能上的问题?

删除之类操作需要全选功能,方便选择 public class MainActivity extends Activity { private ListView lv; private MyAdapter mAdapter; private ArrayList list; private Button bt_selectall; // private Button bt_cancel; // private Button bt_deselectall; private int checkNum; // 记录选中的条目数量 private TextView tv_show;// 用于显示选中的条目数量 /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); /* 实例化各个控件 */ lv = (ListView) findViewById(R.id.lv); bt_selectall = (Button) findViewById(R.id.bt_selectall); // bt_cancel = (Button) findViewById(R.id.bt_cancelselectall); // bt_deselectall = (Button) findViewById(R.id.bt_deselectall); tv_show = (TextView) findViewById(R.id.tv); list = new ArrayList(); // 为Adapter准备数据 initDate(); // 实例化自定义的MyAdapter mAdapter = new MyAdapter(list, this); // 绑定Adapter lv.setAdapter(mAdapter); // 全选按钮的回调接口 bt_selectall.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将MyAdapter中的map值全部设为true for (int i = 0; i < list.size(); i++) { MyAdapter.getIsSelected().put(i, true); } // 数量设为list的长度 checkNum = list.size(); // 刷新listview和TextView的显示 dataChanged(); } }); // 反选按钮的回调接口 // bt_cancel.setOnClickListener(new OnClickListener() { // @Override // public void onClick(View v) { // // 遍历list的长度,将已选的设为未选,未选的设为已选 // for (int i = 0; i < list.siz
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liugang0605

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值