layui表单 -- form元素

本文详细介绍了layui前端框架中的表单元素,包括text、password、checkbox、radio、file等,以及form表单的提交、清空、隐藏域等。重点讲解了layui的模块加载、样式命名规范和JS使用,如layui.use()、layui.form、layui.layer、layui.layedit、layui.laydate等。内容涵盖自定义验证规则、下拉选择、日期选择器、编辑器、开关、单选框、复选框、文本域等表单元素的使用方法和示例代码,展示了如何监听表单事件,如提交、开关切换等。

form表单元素包括:text 文本输入框,password密码输入框,checkbox复选框,radio单选框,file 文件域,submit表单提交action指向的文件,reset表单清空,image图片提交按钮,button按钮,hidden隐藏域。

select option select 实现下拉选

callback 是回调函数

layui.模块   模块可以是layui已经存在的模块,也可以通过layui.define([mods], callback) 来自己自定义模块。

如果想要使用模块首先要做的必然是加载模块,layui.use(['laypage', 'layedit'], function(){});


接下来使用layui风格控件 
其实感觉layui帮我们定义好了CSS和许多JS文本,我们需要做的只是按照layui的命名规范选好样式进而使用就可以了。 
layu官方文档的命名规范为:

CSS命名规范
class命名前缀:layui,连接符:-,如:class="layui-form"

命名格式一般分为两种:
一:layui-模块名-状态或类型
二:layui-状态或类型
因为有些类并非是某个模块所特有,他们通常会是一些公共类。如:
一(定义按钮的原始风格):class="layui-btnlayui-btn-primary"
二(定义内联块状元素):class="layui-inline"

当然还有前面提到的使用模块的js代码:

<script>
layui.use(['form', 'layedit', 'laydate'], function(){
  var form = layui.form
  ,layer = layui.layer
  ,layedit = layui.layedit
  ,laydate = layui.laydate;

  //日期
  laydate.render({
    elem: '#date'
  });
  laydate.render({
    elem: '#date1'
  });

  //创建一个编辑器
  var editIndex = layedit.build('LAY_demo_editor');

  //自定义验证规则
  form.verify({
    title: function(value){
      if(value.length < 5){
        return '标题至少得5个字符啊';
      }
    }
    ,pass: [/(.+){6,12}$/, '密码必须6到12位']
    ,content: function(value){
      layedit.sync(editIndex);
    }
  });

  //监听指定开关
  form.on('switch(switchTest)', function(data){
    layer.msg('开关checked:'+ (this.checked ? 'true' : 'false'), {
      offset: '6px'
    });
    layer.tips('温馨提示:请注意开关状态的文字可以随意定义,而不仅仅是ON|OFF', data.othis)
  });

  //监听提交
  form.on('submit(demo1)', function(data){
    layer.alert(JSON.stringify(data.field), {
      title: '最终的提交信息'
    })
    return false;
  });


});
</script>

下面我们按照官方文档的开发规范使用一下form表单的例子

<form class="layui-form" action="">
    <fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
  <legend>表单集合演示</legend>
    </fieldset>
  <div class="layui-form-item">
    <label class="layui-form-label">单行输入框</label>
    <div class="layui-input-block">
      <input type="text" name="title" lay-verify="title" autocomplete="off" placeholder="请输入标题" class="layui-input" style="width:200px;">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">验证必填项</label>
    <div class="layui-input-block">
      <input type="text" name="username" lay-verify="required" placeholder="请输入" autocomplete="off" class="layui-input">
    </div>
  </div>

  <div class="layui-form-item">
    <div class="layui-inline">
      <label class="layui-form-label">验证手机</label>
      <div class="layui-input-inline">
        <input type="tel" name="phone" lay-verify="phone" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-inline">
      <label class="layui-form-label">验证邮箱</label>
      <div class="layui-input-inline">
        <input type="text" name="email" lay-verify="email" autocomplete="off" class="layui-input">
      </div>
    </div>
  </div>

  <div class="layui-form-item">
    <div class="layui-inline">
      <label class="layui-form-label">多规则验证</label>
      <div class="layui-input-inline">
        <input type="text" name="number" lay-verify="required|number" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-inline">
      <label class="layui-form-label">验证日期</label>
      <div class="layui-input-inline">
        <input type="text" name="date" id="date" lay-verify="date" placeholder="yyyy-MM-dd" autocomplete="off" class="layui-input">
      </div>
    </div>
    <div class="layui-inline">
      <label class="layui-form-label">验证链接</label>
      <div class="layui-input-inline">
        <input type="tel" name="url" lay-verify="url" autocomplete="off" class="layui-input">
      </div>
    </div>
  </div>

  <div class="layui-form-item">
    <label class="layui-form-label">验证身份证</label>
    <div class="layui-input-block">
      <input type="text" name="identity" lay-verify="identity" placeholder="" autocomplete="off" class="layui-input">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">自定义验证</label>
    <div class="layui-input-inline">
      <input type="password" name="password" lay-verify="pass" placeholder="请输入密码" autocomplete="off" class="layui-input">
    </div>
    <div class="layui-form-mid layui-word-aux">请填写6到12位密码</div>
  </div>

  <div class="layui-form-item">
    <div class="layui-inline">
      <label class="layui-form-label">范围</label>
      <div class="layui-input-inline" style="width: 100px;">
        <input type="text" name="price_min" placeholder="¥" autocomplete="off" class="layui-input">
      </div>
      <div class="layui-form-mid">-</div>
      <div class="layui-input-inline" style="width: 100px;">
        <input type="text" name="price_max" placeholder="¥" autocomplete="off" class="layui-input">
      </div>
    </div>
  </div>

  <div class="layui-form-item">
    <label class="layui-form-label">单行选择框</label>
    <div class="layui-input-block">
      <select name="interest" lay-filter="aihao">
        <option value=""></option>
        <option value="0">写作</option>
        <option value="1" selected="">阅读</option>
        <option value="2">游戏</option>
        <option value="3">音乐</option>
        <option value="4">旅行</option>
      </select>
    </div>
  </div>


  <div class="layui-form-item">
    <div class="layui-inline">
      <label class="layui-form-label">分组选择框</label>
      <div class="layui-input-inline">
        <select name="quiz">
          <option value="">请选择问题</option>
          <optgroup label="城市记忆">
            <option value="你工作的第一个城市">你工作的第一个城市</option>
          </optgroup>
          <optgroup label="学生时代">
            <option value="你的工号">你的工号</option>
            <option value="你最喜欢的老师">你最喜欢的老师</option>
          </optgroup>
        </select>
      </div>
    </div>
    <div class="layui-inline">
      <label class="layui-form-label">搜索选择框</label>
      <div class="layui-input-inline">
        <select name="modules" lay-verify="required" lay-search="">
          <option value="">直接选择或搜索选择</option>
          <option value="1">layer</option>
          <option value="2">form</option>
          <option value="3">layim</option>
          <option value="4">element</option>
          <option value="5">laytpl</option>
          <option value="6">upload</option>
          <option value="7">laydate</option>
          <option value="8">laypage</option>
          <option value="9">flow</option>
          <option value="10">util</option>
          <option value="11">code</option>
          <option value="12">tree</option>
          <option value="13">layedit</option>
          <option value="14">nav</option>
          <option value="15">tab</option>
          <option value="16">table</option>
          <option value="17">select</option>
          <option value="18">checkbox</option>
          <option value="19">switch</option>
          <option value="20">radio</option>
        </select>
      </div>
    </div>
  </div>

  <div class="layui-form-item">
    <label class="layui-form-label">联动选择框</label>
    <div class="layui-input-inline">
      <select name="quiz1">
        <option value="">请选择省</option>
        <option value="浙江" selected="">浙江省</option>
        <option value="你的工号">江西省</option>
        <option value="你最喜欢的老师">福建省</option>
      </select>
    </div>
    <div class="layui-input-inline">
      <select name="quiz2">
        <option value="">请选择市</option>
        <option value="杭州">杭州</option>
        <option value="宁波" disabled="">宁波</option>
        <option value="温州">温州</option>
        <option value="温州">台州</option>
        <option value="温州">绍兴</option>
      </select>
    </div>
    <div class="layui-input-inline">
      <select name="quiz3">
        <option value="">请选择县/区</option>
        <option value="西湖区">西湖区</option>
        <option value="余杭区">余杭区</option>
        <option value="拱墅区">临安市</option>
      </select>
    </div>
    <div class="layui-form-mid layui-word-aux">此处只是演示联动排版,并未做联动交互</div>
  </div>

  <div class="layui-form-item">
    <label class="layui-form-label">复选框</label>
    <div class="layui-input-block">
      <input type="checkbox" name="like[write]" title="写作">
      <input type="checkbox" name="like[read]" title="阅读" checked="">
      <input type="checkbox" name="like[game]" title="游戏">
    </div>
  </div>

  <div class="layui-form-item" pane="">
    <label class="layui-form-label">原始复选框</label>
    <div class="layui-input-block">
      <input type="checkbox" name="like1[write]" lay-skin="primary" title="写作" checked="">
      <input type="checkbox" name="like1[read]" lay-skin="primary" title="阅读">
      <input type="checkbox" name="like1[game]" lay-skin="primary" title="游戏" disabled="">
    </div>
  </div>

  <div class="layui-form-item">
    <label class="layui-form-label">开关-默认关</label>
    <div class="layui-input-block">
      <input type="checkbox" name="close" lay-skin="switch" lay-text="ON|OFF">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">开关-默认开</label>
    <div class="layui-input-block">
      <input type="checkbox" checked="" name="open" lay-skin="switch" lay-filter="switchTest" lay-text="ON|OFF">
    </div>
  </div>
  <div class="layui-form-item">
    <label class="layui-form-label">单选框</label>
    <div class="layui-input-block">
      <input type="radio" name="sex" value="男" title="男" checked="">
      <input type="radio" name="sex" value="女" title="女">
      <input type="radio" name="sex" value="禁" title="禁用" disabled="">
    </div>
  </div>
  <div class="layui-form-item layui-form-text">
    <label class="layui-form-label">普通文本域</label>
    <div class="layui-input-block">
      <textarea placeholder="请输入内容" class="layui-textarea"></textarea>
    </div>
  </div>
  <div class="layui-form-item layui-form-text">
    <label class="layui-form-label">编辑器</label>
    <div class="layui-input-block">
      <textarea class="layui-textarea layui-hide" name="content" lay-verify="content" id="LAY_demo_editor"></textarea>
    </div>
  </div>
  <div class="layui-form-item">
    <div class="layui-input-block">
      <button class="layui-btn" lay-submit="" lay-filter="demo1">立即提交</button>
      <button type="reset" class="layui-btn layui-btn-primary">重置</button>
    </div>
  </div>
</form>

首先贴出JS中的代码:

<script>
layui.use(['form', 'layedit', 'laydate'], function(){
  var form = layui.form
  ,layer = layui.layer
  ,layedit = layui.layedit
  ,laydate = layui.laydate;

  //日期
  laydate.render({
    elem: '#date'
  });
  laydate.render({
    elem: '#date1'
  });

  //创建一个编辑器
  var editIndex = layedit.build('LAY_demo_editor');

  //自定义验证规则
  form.verify({
    title: function(value){
      if(value.length < 5){
        return '标题至少得5个字符啊';
      }
    }
    ,pass: [/(.+){6,12}$/, '密码必须6到12位']
    ,content: function(value){
      layedit.sync(editIndex);
    }
  });

  //监听指定开关
  form.on('switch(switchTest)', function(data){
    layer.msg('开关checked:'+ (this.checked ? 'true' : 'false'), {
      offset: '6px'
    });
    layer.tips('温馨提示:请注意开关状态的文字可以随意定义,而不仅仅是ON|OFF', data.othis)
  });

  //监听提交
  form.on('submit(demo1)', function(data){
    layer.alert(JSON.stringify(data.field), {
      title: '最终的提交信息'
    })
    return false;
  });


});
</script>

layui.use()不用说,引入依赖模块[‘form’, ‘layedit’, ‘laydate’]并赋值调用相应模块接口,首先来看laydate这个模块:

  laydate.render({
    elem: '#date'
  });
  函数原型:laydate.render([options]);
  options为控件参数。

从示例中可以看出空间参数才用key/value的赋值形式,laydate有一些基础参数(参考官网的开发文档)

elem:指定元素 ,‘#date’是指id为date的元素。

type:控件选择类型。相当于选择这个日期控件是选择年呢还是年月呢还是年月日呢?就类似于java里的日期类的format,指定一个日期类型。 
type也有一些参数选择:

type可选值    名称    用途
year    年选择器    只提供年列表选择
month    年月选择器    只提供年、月选择
date    日期选择器    可选择:年、月、日。type默认值,一般可不填
time    时间选择器    只提供时、分、秒选择
datetime    日期时间选择器    可选择:年、月、日、时、分、秒
range:开启左右面板范围选择 。类型:Boolean/String,默认值:false

如果设置 true,将默认采用 “ - ” 分割。 你也可以直接设置 分割字符。五种选择器类型均支持左右面板的范围选择。emmmm我没怎么懂这个是啥,不过感觉不太重要,结合具体的控件看看就好。

下面真的还有多参数,具体可以参考官网的对应开发文档,都比较简单易懂,还可以定义一些回调函数,非常方便

接下来来看看编辑器模块’layedit’:

var editIndex = layedit.build('LAY_demo_editor');
1
函数原型:layedit.build(id,options)

id即为元素id,options和前面的laydate的options一样为编辑框的基本参数,也同样才用key/value的形式赋值。 
至于 var editIndex = layedit.build(‘LAY_demo_editor’);的操作是将用于得到build方法返回的索引,嗯,我目前也不懂可以干啥,不过官方文档中说也提供很多编辑方法,非常实用:

方法名    描述
var index = layedit.build(id, options)    用于建立编辑器的核心方法,index:即该方法返回的索引
layedit.set(options)    设置编辑器的全局属性 即上述build方法的options
layedit.getContent(index)    获得编辑器的内容,参数 index: 即执行layedit.build返回的值
layedit.getText(index)    获得编辑器的纯文本内容,参数 index: 同上
layedit.sync(index)    用于同步编辑器内容到textarea(一般用于异步提交),参数 index: 同上
layedit.getSelection(index)    获取编辑器选中的文本 ,参数 index: 同上
关于编辑器的基础设置这里就不赘述了,和laydate的形式一样,具体可以参考官方开发文档

接下来就是自定义验证规则:

  form.verify({
    title: function(value){
      if(value.length < 5){
        return '标题至少得5个字符啊';
      }
    }
    ,pass: [/(.+){6,12}$/, '密码必须6到12位']
    ,content: function(value){
      layedit.sync(editIndex);
    }
  });

这是表单模块中提供的自定义验证规则,先让我们来看看简单的,即layui已经帮我们集成的验证规则,只需要在表单元素上加上lay-verify=”value”即可,value可以是一个也可以是多个,例如:

<input type="text" lay-verify="email"> 

还同时支持多条规则的验证,如下:
<input type="text" lay-verify="required|phone|number">

目前layui内置的验证属性:
required(必填项)
phone(手机号)
email(邮箱)
url(网址)
number(数字)
date(日期)
identity(身份证)
同时也支持自定义规则:

layui.code
form.verify({
  username: function(value, item){ //value:表单的值、item:表单的DOM对象
    if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){
      return '用户名不能有特殊字符';
    }
    if(/(^\_)|(\__)|(\_+$)/.test(value)){
      return '用户名首尾不能出现下划线\'_\'';
    }
    if(/^\d+\d+\d$/.test(value)){
      return '用户名不能全为数字';
    }
  }

  //我们既支持上述函数式的方式,也支持下述数组的形式
  //数组的两个值分别代表:[正则匹配、匹配不符时的提示文字]
  ,pass: [
    /^[\S]{6,12}$/
    ,'密码必须6到12位,且不能出现空格'
  ] 
});  

参考官网的模型,form.verify(options);中也是才用key/value的形式, 
例如 username:function(value,item){}中username是这个验证的名字,function即验证体,观察发现验证体可能有两种,一种是function(value,item){}的方法体形式(其中value是表单元素中的值,item是元素对象,可以不填好像,填的话DOM对象也很好提取的),还有一种是[reg,error]的形式,即[正则表达式,错误提示文本].方法体中的错误提示文本则才用return的形式返回。

最后是表单的监听:

  //监听指定开关
  form.on('switch(switchTest)', function(data){
    layer.msg('开关checked:'+ (this.checked ? 'true' : 'false'), {
      offset: '6px'
    });
    layer.tips('温馨提示:请注意开关状态的文字可以随意定义,而不仅仅是ON|OFF', data.othis)
  });

  //监听提交
  form.on('submit(demo1)', function(data){
    layer.alert(JSON.stringify(data.field), {
      title: '最终的提交信息'
    })
    return false;
  });

函数原型:form.on(‘event(过滤器值)’, callback);

event    描述
select    监听select下拉选择事件
checkbox    监听checkbox复选框勾选事件
switch    监听checkbox复选框开关事件
radio    监听radio单选框事件
submit    监听表单提交事件
这些是form专属的event的值 
默认是监听所有元素,如果监听个别元素,可以用事件选择器,同时指定过滤器的值:

例如:
<select lay-filter="test"></select>

其中lay-filter=“XXX”即是过滤器值。 
在回调函数中定义事件监听的操作即可。

form表单元素包括:text 文本输入框,password密码输入框,checkbox复选框,radio单选框,file 文件域,submit表单提交action指向的文件,reset表单清空,image图片提交按钮,button按钮,hidden隐藏域。 select option select 实现下拉选 callback 是回调函数 layui.模块   模块可以是layui已经存在的模块,也可以通过layui.define([mods], callback) 来自己自定义模块。 如果想要使用模块首先要做的必然是加载模块,layui.use(['laypage', 'layedit'], function(){}); 接下来使用layui风格控件  其实感觉layui帮我们定义好了CSS和许多JS文本,我们需要做的只是按照layui的命名规范选好样式进而使用就可以了。  layu官方文档的命名规范为: CSS命名规范 class命名前缀:layui,连接符:-,如:class="layui-form" 命名格式一般分为两种: 一:layui-模块名-状态或类型 二:layui-状态或类型 因为有些类并非是某个模块所特有,他们通常会是一些公共类。如: 一(定义按钮的原始风格):class="layui-btnlayui-btn-primary" 二(定义内联块状元素):class="layui-inline" 1 2 3 4 5 6 7 8 9 当然还有前面提到的使用模块的js代码: layui.use(['form', 'layedit', 'laydate'], function(){   var form = layui.form   ,layer = layui.layer   ,layedit = layui.layedit   ,laydate = layui.laydate;   //日期   laydate.render({     elem: '#date'   });   laydate.render({     elem: '#date1'   });   //创建一个编辑器   var editIndex = layedit.build('LAY_demo_editor');   //自定义验证规则   form.verify({     title: function(value){       if(value.length < 5){         return '标题至少得5个字符啊';       }     }     ,pass: [/(.+){6,12}$/, '密码必须6到12位']     ,content: function(value){       layedit.sync(editIndex);     }   });   //监听指定开关   form.on('switch(switchTest)', function(data){     layer.msg('开关checked:'+ (this.checked ? 'true' : 'false'), {       offset: '6px'     });     layer.tips('温馨提示:请注意开关状态的文字可以随意定义,而不仅仅是ON|OFF', data.othis)   });   //监听提交   form.on('submit(demo1)', function(data){     layer.alert(JSON.stringify(data.field), {       title: '最终的提交信息'     })     return false;   }); }); 下面我们按照官方文档的开发规范使用一下form表单的例子       表单集合演示           单行输入框                       验证必填项                             验证手机                                   验证邮箱                                       多规则验证                                   验证日期                                   验证链接                                 验证身份证                       自定义验证                   请填写6到12位密码               范围                           -                                 单行选择框                   </opt
<think>我们面对的是一个Layui渲染的复选框,其结构为: 原始input[type=checkbox]被隐藏,然后生成一个div.layui-form-checkbox来显示样式。 当选中时,这个div会添加类"layui-form-checked",并且对应的原始checkbox会被设置为checked。 要求:删除选中状态以及对应的value。注意,这里有两个操作: 1. 移除div的"layui-form-checked"类(即视觉上的选中状态) 2. 将原始checkbox的checked属性设置为false,并且清除其value(这里注意:复选框的value通常不会改变,我们一般是改变checked状态,而value是固定的。所以清除value可能是指将表单中该复选框的值清除?) 但是,根据常见的需求,我们通常不会改变复选框的value属性(因为每个复选框的value是预设的),而是改变其是否被选中。所以这里可能有两种理解: - 清除复选框的选中状态(即checked设为false)并且将对应表单字段的值清空(在表单提交时,未选中的复选框不会提交,所以不需要特别清空值) - 或者,将复选框的value属性置为空?但这样通常不合理,因为复选框的value是固定的。 根据问题描述,我们可能要做的是: 1. 移除视觉样式(layui-form-checked类) 2. 设置原始checkbox的checked为false 3. 将原始checkbox的value设置为空字符串(或者移除value属性?) 但是,请注意:在Layui中,复选框的value是定义在原始input上的,而且通常我们不会在选中状态改变时去修改value,因为每个复选框的value是固定的。所以,这里可能是一个特殊需求:不仅要取消选中,还要把该复选框的value属性清空。 因此,我们分两步: 第一步:找到每个需要处理的复选框(通过选择器找到对应的.layui-form-checkbox元素) 第二步:遍历这些元素,对每个元素: a. 移除layui-form-checked类 b. 找到对应的原始checkbox(因为Layui渲染的复选框,原始input在样式div的前面,所以可以用prev()方法) c. 设置原始checkbox的checked为false d. 设置原始checkbox的value为空(或者根据需求移除value) 另外,注意:如果清除了value,那么当这个复选框再次被选中时,提交的值就是空字符串了。这可能是需求,也可能不是。所以请根据实际场景决定。 代码示例: 假设我们有一个复选框组,我们要清除其中所有选中的复选框的选中状态并清空value。 但是,问题中给了一个选择器:`$('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox')`,所以我们基于这个选择器操作。 修改后的代码: ```javascript $('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox').each(function() { // 移除选中样式 $(this).removeClass('layui-form-checked'); // 获取原始checkbox(Layui渲染时,原始input在样式div的前面,所以用prev) var $input = $(this).prev('input[type="checkbox"]'); // 取消选中 $input.prop('checked', false); // 清空value值(设置为空字符串) $input.val(''); // 或者,如果你想移除value属性(注意:移除后,该复选框就没有value属性了,提交时可能使用默认值?) // $input.removeAttr('value'); }); // 重新渲染表单(虽然我们修改了原始checkbox,但Layui的样式已经通过removeClass更新了,但为了确保一致,可以调用render) layui.form.render(); ``` 但是,请注意:在Layui中,修改原始input的value并不会直接反映在渲染的组件上,因为渲染的组件显示的是title,而提交的是value。所以清空value后,提交表单时该字段的值就是空字符串(如果该复选框被重新选中)。 另外,如果复选框是动态生成的,或者有事件监听,需要注意是否会影响。 完整示例: 由于问题中要求不要用原生js,使用jQuery,所以以上代码是jQuery写法。 下面是一个完整的示例,包括HTML结构: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>清空复选框状态和值</title> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/layui@2.6.8/dist/css/layui.css"> <script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script> </head> <body> <div class="layui-form"> <!-- 不会被清空的区域 --> <div id="constructionSecondary" class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">保留区域</label> <div class="layui-input-block"> <input type="checkbox" name="keep1" value="keep-value1" title="保留选项1"> <input type="checkbox" name="keep2" value="keep-value2" title="保留选项2"> </div> </div> </div> <!-- 会被清空的区域 --> <div class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">清空区域1</label> <div class="layui-input-block"> <input type="checkbox" name="clear1" value="value1" title="选项1" checked> <input type="checkbox" name="clear2" value="value2" title="选项2"> </div> </div> </div> <!-- 另一个会被清空的区域 --> <div class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">清空区域2</label> <div class="layui-input-block"> <input type="checkbox" name="clear3" value="value3" title="选项3"> <input type="checkbox" name="clear4" value="value4" title="选项4" checked> </div> </div> </div> <button id="clearBtn" class="layui-btn">清空非保留区域</button> </div> <script src="https://cdn.jsdelivr.net/npm/layui@2.6.8/dist/layui.js"></script> <script> layui.use(['form', 'layer'], function() { var form = layui.form; var layer = layui.layer; // 清空按钮点击事件 $('#clearBtn').click(function() { // 清空除 #constructionSecondary 外的所有区域 $('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox').each(function() { // 移除选中样式 $(this).removeClass('layui-form-checked'); // 获取原始checkbox var $input = $(this).prev('input[type="checkbox"]'); // 取消选中 $input.prop('checked', false); // 清空value值(设置为空字符串) $input.val(''); }); // 更新Layui表单状态(虽然我们移除了样式,但重新渲染确保一致) form.render(); // 显示操作结果 layer.msg('已清空非保留区域的复选框状态和值'); }); }); </script> </body> </html> ``` 注意:在这个示例中,初始时有两个复选框是选中的(有checked属性)。点击按钮后,这两个复选框的选中状态会被取消,并且它们的value属性会被设置为空字符串。 但是,这里有一个问题:在Layui中,复选框的value被清空后,如果用户再次选中,那么提交的值就是空字符串。这可能是期望的,也可能不是。请根据实际需求决定是否清空value。 如果需求只是取消选中状态,而不改变value,那么就不需要`$input.val('');`这一行。 因此,请根据实际需求选择操作。 §§相关问题§§ 1. 在Layui中,如何获取复选框的原始DOM元素? 2. 清空复选框的value属性会对表单提交产生什么影响? 3. 除了使用.prev()方法,还有哪些方式可以获取Layui渲染的复选框对应的原始input? 4. 如何只清空特定名称(name)的复选框状态和值? 5. 在清空复选框状态后,如何确保Layui的样式正确更新?</think>以下是根据您需求修改的代码,使用 jQuery 删除 Layui 复选框的选中状态并清除对应的 value 值: ```javascript // 选择所有需要处理的复选框元素 $('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox').each(function() { // 移除选中状态样式 $(this).removeClass('layui-form-checked'); // 获取对应的原始复选框元素 var $checkbox = $(this).prev('input[type="checkbox"]'); // 取消选中状态 $checkbox.prop('checked', false); // 清除value值(两种方式可选) // 方式1:重置为默认值(需要知道默认值) // $checkbox.val('default-value'); // 方式2:清空value值(推荐) $checkbox.val(''); // 方式3:移除value属性(彻底删除) // $checkbox.removeAttr('value'); }); // 更新Layui表单状态 layui.form.render(); ``` ### 完整实现代码(带HTML结构) ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>删除复选框选中状态及值</title> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/layui@2.6.8/dist/css/layui.css"> <script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script> </head> <body> <div class="layui-form"> <!-- 不会被处理的区域 --> <div id="constructionSecondary" class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">保留区域</label> <div class="layui-input-block"> <input type="checkbox" name="keep1" value="keep-value1" title="保留选项1" checked> <input type="checkbox" name="keep2" value="keep-value2" title="保留选项2"> </div> </div> </div> <!-- 会被处理的区域 --> <div class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">处理区域1</label> <div class="layui-input-block"> <input type="checkbox" name="clear1" value="value1" title="选项1" checked> <div class="layui-unselect layui-form-checkbox layui-form-checked" lay-skin="primary"> <i class="layui-icon layui-icon-ok"></i> </div> <input type="checkbox" name="clear2" value="value2" title="选项2"> <div class="layui-unselect layui-form-checkbox" lay-skin="primary"> <i class="layui-icon layui-icon-ok"></i> </div> </div> </div> </div> <!-- 另一个会被处理的区域 --> <div class="secondary-container"> <div class="layui-form-item"> <label class="layui-form-label">处理区域2</label> <div class="layui-input-block"> <input type="checkbox" name="clear3" value="value3" title="选项3"> <div class="layui-unselect layui-form-checkbox" lay-skin="primary"> <i class="layui-icon layui-icon-ok"></i> </div> <input type="checkbox" name="clear4" value="value4" title="选项4" checked> <div class="layui-unselect layui-form-checkbox layui-form-checked" lay-skin="primary"> <i class="layui-icon layui-icon-ok"></i> </div> </div> </div> </div> <button id="clearBtn" class="layui-btn">删除选中状态及值</button> </div> <script src="https://cdn.jsdelivr.net/npm/layui@2.6.8/dist/layui.js"></script> <script> layui.use(['form', 'layer'], function() { var form = layui.form; var layer = layui.layer; // 清空按钮点击事件 $('#clearBtn').click(function() { // 处理除 #constructionSecondary 外的所有区域 $('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox').each(function() { // 移除选中样式 $(this).removeClass('layui-form-checked'); // 获取对应的原始复选框 var $checkbox = $(this).prev('input[type="checkbox"]'); // 取消选中状态 $checkbox.prop('checked', false); // 清除value值 $checkbox.val(''); }); // 更新Layui表单状态 form.render(); // 显示操作结果 layer.msg('已删除选中状态并清除值'); // 验证结果 console.log("clear1 value:", $('[name="clear1"]').val()); // 应为 "" console.log("clear4 value:", $('[name="clear4"]').val()); // 应为 "" }); }); </script> </body> </html> ``` ### 关键点说明 1. **DOM 结构处理**: - Layui 渲染的复选框结构:原始 `<input>` 后紧跟 `.layui-form-checkbox` 元素 - 使用 `.prev()` 获取原始复选框元素 ```javascript var $checkbox = $(this).prev('input[type="checkbox"]'); ``` 2. **删除选中状态**: ```javascript // 移除视觉样式 $(this).removeClass('layui-form-checked'); // 取消选中状态 $checkbox.prop('checked', false); ``` 3. **清除 value 值**: ```javascript // 推荐方式:设置为空字符串 $checkbox.val(''); // 替代方式:完全移除value属性 // $checkbox.removeAttr('value'); ``` 4. **Layui 更新**: ```javascript layui.form.render(); // 必须调用以更新UI ``` 5. **选择器优化**: ```javascript $('.secondary-container').not('#constructionSecondary').find('.layui-form-checkbox') ``` - 精确选择需要处理的元素 - 排除特定区域 ### 不同清除值的方法对比 | 方法 | 效果 | 适用场景 | |--------------------------|----------------------------------|----------------------------| | `$checkbox.val('')` | 设置value属性为空字符串 | 推荐,保留属性结构 | | `$checkbox.removeAttr('value')` | 完全移除value属性 | 需要完全移除值时使用 | | `$checkbox.val(null)` | 设置value为null | 不推荐,可能产生意外行为 | | `$checkbox.attr('value', '')` | 设置value属性为空字符串 | 与.val('')效果相同 | ### 额外建议 如果需要重置整个表单,可以使用 Layui表单重置功能: ```javascript // 重置整个表单 $('form')[0].reset(); layui.form.render(); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值