html+css 防止多次点击开关,并控制遍历中的数据判断开关按钮的数量

<style type="text/css">
    .chooseBtn {
        display: none;
    }
    .choose-label {
        box-shadow: #ccc 0px 0px 0px 1px;
        width: 40px;
        height: 20px;
        display: inline-block;
        border-radius: 20px;
        position: relative;
        background-color: #bdbdbd;
        overflow: hidden;
    }
    .choose-label:before {
        content: '';
        position: absolute;
        left: 0;
        width: 20px;
        height: 20px;
        display: inline-block;
        border-radius: 20px;
        background-color: #fff;
        z-index: 20;
        -webkit-transition: all 0.5s;
        transition: all 0.5s;
    }
    .chooseBtn:checked + label.choose-label:before {
        left: 20px;
    }
    .chooseBtn:checked + label.choose-label {
        background-color: #51ccee;
    }
</style>

<td class="am-text-middle">
    <input type="checkbox" name="sex" id="male.<?= $key ?>" class="chooseBtn "
        <?php if($first['is_publish'] == 1 ): ?>
            checked
        <?php endif; ?>
           onclick="choose_fun(<?=  $first['article_images_id'] ?>,<?= $key?>)" />
    <label for="male.<?= $key ?>" class="choose-label"></label>
</td>
<script>
    //更新数据
    var couldRun = true;
    function choose_fun(article_images_id,key) {
        if(couldRun){
            couldRun = false;
            //获取当前被选中数量
            var str = $(".chooseBtn:checked").length;
            var check = $(".chooseBtn").eq(key).is(":checked");
            if(check){
                if(str > 5) {
                    layer.msg('数量不可以大于5');
                    $(".chooseBtn").eq(key).removeAttr('checked');
                    return false;
                }
            }
            else{
                if(str < 1){
                    layer.msg('数量不可以小于1');
                    $(".chooseBtn").eq(key).prop('checked',true);
                    return false;
                }
            }
            $.ajax({
                url: "<?= url('content.article/imagesUpdate') ?>",
                type:"POST",
                dataType: 'text',
                data:{
                    article_images_id:article_images_id
                },
                dataType:"json",
                success: function(data){
                    if(data === 1){
                        layer.msg("修改成功!");
                    }else if(data === 2){
                        layer.msg("开启失败(显示数量已达上限!)");
                    }
                    else{
                        layer.msg("关闭失败(显示数量已达下限!)");
                    }
                }
            });
            setTimeout(function(){
                couldRun = true;
            },1000);
        }else{
            var check = $(".chooseBtn").eq(key).is(":checked");
            if(check){
                layer.msg('请勿连续点击!');
                $(".chooseBtn").eq(key).removeAttr('checked');
                return false;
            }else{
                layer.msg('请勿连续点击!');
                $(".chooseBtn").eq(key).prop('checked',true);
                return false;
            }
        }
    }
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
由于涉及到服务器文件的遍历,需要使用服务器端的代码。以下是使用Node.js实现服务器文件遍历的示例代码: ```javascript const fs = require('fs'); // 定义遍历函数 function traverseFolder(folderPath) { fs.readdir(folderPath, function(err, files) { if (err) { console.error(err); return; } files.forEach(function(file) { const fullPath = folderPath + '/' + file; fs.stat(fullPath, function(err, stats) { if (err) { console.error(err); return; } if (stats.isDirectory()) { // 如果是文件夹,递归进入 traverseFolder(fullPath); } else { // 如果是文件,可以做相应的处理 console.log(fullPath); } }); }); }); } // 调用遍历函数 traverseFolder('/path/to/your/folder'); ``` 上述代码,`traverseFolder`函数用于遍历指定路径下的所有文件和文件夹。对于每个文件夹,递归进入;对于每个文件,可以做相应的处理,例如打印路径。 此外,还需要在Node.js使用HTTP模块搭建一个简单的Web服务器,以便在浏览器访问文件列表。以下是示例代码: ```javascript const http = require('http'); const fs = require('fs'); const path = require('path'); // 定义遍历函数 function traverseFolder(folderPath, callback) { fs.readdir(folderPath, function(err, files) { if (err) { callback(err); return; } const results = []; files.forEach(function(file) { const fullPath = folderPath + '/' + file; fs.stat(fullPath, function(err, stats) { if (err) { callback(err); return; } const item = { name: file, path: fullPath, isDirectory: stats.isDirectory() }; if (stats.isDirectory()) { // 如果是文件夹,递归进入 traverseFolder(fullPath, function(err, children) { if (err) { callback(err); return; } item.children = children; results.push(item); if (results.length === files.length) { callback(null, results); } }); } else { // 如果是文件,直接添加到结果数组 results.push(item); if (results.length === files.length) { callback(null, results); } } }); }); }); } // 创建HTTP服务器 const server = http.createServer(function(req, res) { // 获取当前路径 const currentPath = '.' + req.url; // 如果是文件,直接返回文件内容 if (fs.existsSync(currentPath) && fs.statSync(currentPath).isFile()) { fs.readFile(currentPath, function(err, data) { if (err) { res.writeHead(500); res.end(); return; } res.writeHead(200, { 'Content-Type': 'text/plain' }); res.end(data); }); return; } // 如果是文件夹,返回文件列表 traverseFolder(currentPath, function(err, results) { if (err) { res.writeHead(500); res.end(); return; } // 生成HTML代码,展示文件列表 let html = '<ul>'; results.forEach(function(item) { html += '<li>'; if (item.isDirectory) { html += '<a href="' + item.path + '">' + item.name + '</a>'; if (item.children) { html += '<ul>'; item.children.forEach(function(child) { html += '<li><a href="' + child.path + '">' + child.name + '</a></li>'; }); html += '</ul>'; } } else { html += item.name; } html += '</li>'; }); html += '</ul>'; res.writeHead(200, { 'Content-Type': 'text/html' }); res.end(html); }); }); // 启动服务器 server.listen(8080, function() { console.log('Server is listening on port 8080'); }); ``` 上述代码,`traverseFolder`函数的作用与之前的示例代码相同,但这里将结果包装为一个对象数组,以便在浏览器进行展示。同时,返回的结果是一个异步回调函数的参数,而非直接输出到控制台。 在HTTP服务器,首先判断当前请求的路径是否是一个文件,如果是,则直接返回文件内容。否则,调用`traverseFolder`函数获取文件列表,并生成HTML代码,向浏览器输出。需要注意的是,这里使用了`fs.existsSync`和`fs.statSync`函数判断当前路径是否是一个文件,以避免遍历整个文件夹。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值