form.html 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>镜像站@表单模块文档 - Layui</title>
  6. <meta name="renderer" content="webkit">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  8. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  9. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  10. <meta name="apple-mobile-web-app-capable" content="yes">
  11. <meta name="format-detection" content="telephone=no">
  12. <script>
  13. ;!function(){self!==parent&&(location.href="http://www.baidu.com/")}();
  14. </script>
  15. <link rel="stylesheet" href="/public/layui/dist/css/layui.css" tppabs="http://res.layui.com/layui/dist/css/layui.css?t=1632428048355" media="all">
  16. <link rel="stylesheet" href="/public/static/css/global.css" tppabs="http://res.layui.com/static/css/global.css?t=1632428048355-19" media="all">
  17. </head>
  18. <body>
  19. <div class="layui-header header header-doc" autumn>
  20. <div class="layui-container">
  21. <a class="logo" href="../../index.html" tppabs="http://www.layui.com/">
  22. <img src="/public/static/images/layui/logo.png" tppabs="http://res.layui.com/static/images/layui/logo.png" alt="layui">
  23. </a>
  24. <div class="layui-form layui-hide-xs component" lay-filter="LAY-site-header-component"></div>
  25. <div class="layui-hide-xs site-notice"></div>
  26. <ul class="layui-nav" id="LAY_NAV_TOP">
  27. <li class="layui-nav-item layui-this">
  28. <a href="../index.html" tppabs="http://www.layui.com/doc/">文档</a>
  29. </li>
  30. <li class="layui-nav-item ">
  31. <a href="../../demo/index.html" tppabs="http://www.layui.com/demo/">示例</a>
  32. </li>
  33. <li class="layui-nav-item">
  34. <a href="javascript:;">
  35. <!--<span class="layui-badge-dot" style="left:0; right: auto; margin: -4px 0 0 5px;"></span>-->
  36. 周边
  37. </a>
  38. <dl class="layui-nav-child layui-nav-child-c">
  39. <dd class="layui-hide-sm layui-show-xs" lay-unselect>
  40. <a href="https://gitee.com/sentsin/layui/issues" target="_blank" rel="nofollow">问题反馈</a>
  41. <hr>
  42. </dd>
  43. <dd lay-unselect><a href="../../alone.html" tppabs="http://www.layui.com/alone.html" target="_blank" lay-unselect>独立组件</a></dd>
  44. <dd lay-unselect><a href="../../../fly.layui.com/extend/index.html" target="_blank">扩展组件</a></dd>
  45. </dl>
  46. </li>
  47. <li class="layui-nav-item layui-hide-xs">
  48. <a href="http://gitee.com/sentsin/layui/issues" target="_blank" rel="nofollow">反馈</a>
  49. </li>
  50. </ul>
  51. </div>
  52. </div>
  53. <!-- 让IE8/9支持媒体查询,从而兼容栅格 -->
  54. <!--[if lt IE 9]>
  55. <script src="../../../other/html5shiv/r29/html5.min.js" tppabs="https://cdn.staticfile.org/html5shiv/r29/html5.min.js"></script>
  56. <script src="../../../other/respond.js/1.4.2/respond.min.js" tppabs="https://cdn.staticfile.org/respond.js/1.4.2/respond.min.js"></script>
  57. <![endif]-->
  58. <ul class="site-dir">
  59. <li><a href="#use"><cite>使用</cite></a></li>
  60. <li><a href="#render">
  61. <cite>更新渲染</cite> <span class="layui-badge-dot"></span>
  62. </a></li>
  63. <li><a href="#attr"><cite>预设元素属性</cite></a></li>
  64. <li><a href="#on"><cite>事件触发</cite></a></li>
  65. <li><a href="#onselect"><cite>触发select选择</cite></a></li>
  66. <li><a href="#oncheckbox"><cite>触发checkbox复选</cite></a></li>
  67. <li><a href="#onswitch"><cite>触发switch开关</cite></a></li>
  68. <li><a href="#onradio"><cite>触发radio单选</cite></a></li>
  69. <li><a href="#onsubmit"><cite>触发submit提交</cite></a></li>
  70. <li><a href="#val"><cite>表单赋值 / 取值</cite> <span class="layui-badge-dot"></span></a></li>
  71. <li><a href="#verify"><cite>表单验证</cite> <span class="layui-badge-dot"></span></a></li>
  72. </ul>
  73. <div class="layui-container layui-row">
  74. <div class="layui-col-md3">
  75. <div class="layui-panel site-menu">
  76. <ul class="layui-menu layui-menu-lg">
  77. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  78. <div class="layui-menu-body-title">
  79. 基础说明
  80. </div>
  81. <hr>
  82. <ul>
  83. <li class="">
  84. <div class="layui-menu-body-title">
  85. <a href="../index.html" tppabs="http://www.layui.com/doc/">
  86. <span>开始使用 </span>
  87. <span class="layui-font-12 layui-font-gray">Getting Started</span>
  88. </a>
  89. </div>
  90. </li>
  91. <li class="">
  92. <div class="layui-menu-body-title">
  93. <a href="../base/infrastructure.html" tppabs="http://www.layui.com/doc/base/infrastructure.html">
  94. <span>底层方法 </span>
  95. <span class="layui-font-12 layui-font-gray">基础支撑</span>
  96. </a>
  97. </div>
  98. </li>
  99. <li class="">
  100. <div class="layui-menu-body-title">
  101. <a href="../base/element.html" tppabs="http://www.layui.com/doc/base/element.html">
  102. <span>页面元素 </span>
  103. <span class="layui-font-12 layui-font-gray">规范 公共类 属性</span>
  104. </a>
  105. </div>
  106. </li>
  107. <li class="">
  108. <div class="layui-menu-body-title">
  109. <a href="../base/modules.html" tppabs="http://www.layui.com/doc/base/modules.html">
  110. <span>模块规范 </span>
  111. <span class="layui-font-12 layui-font-gray">使用 扩展</span>
  112. </a>
  113. </div>
  114. </li>
  115. <li class="">
  116. <div class="layui-menu-body-title">
  117. <a href="../base/faq.html" tppabs="http://www.layui.com/doc/base/faq.html">
  118. <span>常见问题 </span>
  119. <span class="layui-font-12 layui-font-gray">FAQ</span>
  120. </a>
  121. </div>
  122. </li>
  123. <li class="">
  124. <div class="layui-menu-body-title">
  125. <a href="../base/changelog.html" tppabs="http://www.layui.com/doc/base/changelog.html">
  126. <span>更新日志 </span>
  127. <span class="layui-font-12 layui-font-gray">changelog</span>
  128. <span class="layui-badge-dot"></span>
  129. </a>
  130. </div>
  131. </li>
  132. </ul>
  133. </li>
  134. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  135. <div class="layui-menu-body-title">
  136. 页面元素
  137. </div>
  138. <hr>
  139. <ul>
  140. <li class="">
  141. <div class="layui-menu-body-title">
  142. <a href="../element/layout.html" tppabs="http://www.layui.com/doc/element/layout.html">
  143. <span>布局 </span>
  144. <span class="layui-font-12 layui-font-gray">栅格 后台管理布局</span>
  145. </a>
  146. </div>
  147. </li>
  148. <li class="">
  149. <div class="layui-menu-body-title">
  150. <a href="../element/color.html" tppabs="http://www.layui.com/doc/element/color.html">
  151. <span>颜色 </span>
  152. <span class="layui-font-12 layui-font-gray">主色调 颜色搭配</span>
  153. </a>
  154. </div>
  155. </li>
  156. <li class="">
  157. <div class="layui-menu-body-title">
  158. <a href="../element/icon.html" tppabs="http://www.layui.com/doc/element/icon.html">
  159. <span>图标 </span>
  160. <span class="layui-font-12 layui-font-gray">iconfont 字体图标</span>
  161. </a>
  162. </div>
  163. </li>
  164. <li class="">
  165. <div class="layui-menu-body-title">
  166. <a href="../element/anim.html" tppabs="http://www.layui.com/doc/element/anim.html">
  167. <span>动画 </span>
  168. <span class="layui-font-12 layui-font-gray">内置 CSS3 动画</span>
  169. </a>
  170. </div>
  171. </li>
  172. <li class="">
  173. <div class="layui-menu-body-title">
  174. <a href="../element/button.html" tppabs="http://www.layui.com/doc/element/button.html">
  175. <span>按钮 </span>
  176. <span class="layui-font-12 layui-font-gray">button</span>
  177. </a>
  178. </div>
  179. </li>
  180. <li class="">
  181. <div class="layui-menu-body-title">
  182. <a href="../element/form.html" tppabs="http://www.layui.com/doc/element/form.html">
  183. <span>表单 </span>
  184. <span class="layui-font-12 layui-font-gray">form 元素集合</span>
  185. </a>
  186. </div>
  187. </li>
  188. <li class="">
  189. <div class="layui-menu-body-title">
  190. <a href="../element/nav.html" tppabs="http://www.layui.com/doc/element/nav.html">
  191. <span>导航 </span>
  192. <span class="layui-font-12 layui-font-gray">nav 面包屑</span>
  193. </a>
  194. </div>
  195. </li>
  196. <li class="">
  197. <div class="layui-menu-body-title">
  198. <a href="../element/menu.html" tppabs="http://www.layui.com/doc/element/menu.html">
  199. <span>菜单 </span>
  200. <span class="layui-font-12 layui-font-gray">menu 基础菜单</span>
  201. <span class="layui-badge-dot"></span>
  202. </a>
  203. </div>
  204. </li>
  205. <li class="">
  206. <div class="layui-menu-body-title">
  207. <a href="../element/tab.html" tppabs="http://www.layui.com/doc/element/tab.html">
  208. <span>选项卡 </span>
  209. <span class="layui-font-12 layui-font-gray">Tabs 切换</span>
  210. </a>
  211. </div>
  212. </li>
  213. <li class="">
  214. <div class="layui-menu-body-title">
  215. <a href="../element/progress.html" tppabs="http://www.layui.com/doc/element/progress.html">
  216. <span>进度条 </span>
  217. <span class="layui-font-12 layui-font-gray">progress</span>
  218. </a>
  219. </div>
  220. </li>
  221. <li class="">
  222. <div class="layui-menu-body-title">
  223. <a href="../element/panel.html" tppabs="http://www.layui.com/doc/element/panel.html">
  224. <span>面板 </span>
  225. <span class="layui-font-12 layui-font-gray">panel 卡片 折叠</span>
  226. </a>
  227. </div>
  228. </li>
  229. <li class="">
  230. <div class="layui-menu-body-title">
  231. <a href="../element/table.html" tppabs="http://www.layui.com/doc/element/table.html">
  232. <span>表格 </span>
  233. <span class="layui-font-12 layui-font-gray">静态 table</span>
  234. </a>
  235. </div>
  236. </li>
  237. <li class="">
  238. <div class="layui-menu-body-title">
  239. <a href="../element/badge.html" tppabs="http://www.layui.com/doc/element/badge.html">
  240. <span>徽章 </span>
  241. <span class="layui-font-12 layui-font-gray">小圆点 小边框</span>
  242. </a>
  243. </div>
  244. </li>
  245. <li class="">
  246. <div class="layui-menu-body-title">
  247. <a href="../element/timeline.html" tppabs="http://www.layui.com/doc/element/timeline.html">
  248. <span>时间线 </span>
  249. <span class="layui-font-12 layui-font-gray">timeline</span>
  250. </a>
  251. </div>
  252. </li>
  253. <li class="">
  254. <div class="layui-menu-body-title">
  255. <a href="../element/auxiliar.html" tppabs="http://www.layui.com/doc/element/auxiliar.html">
  256. <span>辅助 </span>
  257. <span class="layui-font-12 layui-font-gray">引用 字段集 横线等</span>
  258. </a>
  259. </div>
  260. </li>
  261. </ul>
  262. </li>
  263. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  264. <div class="layui-menu-body-title">
  265. 内置模块
  266. </div>
  267. <hr>
  268. <ul>
  269. <li class="">
  270. <div class="layui-menu-body-title">
  271. <a href="layer.html" tppabs="http://www.layui.com/doc/modules/layer.html">
  272. <span>弹出层 </span>
  273. <span class="layui-font-12 layui-font-gray">layer</span>
  274. </a>
  275. </div>
  276. </li>
  277. <li class="">
  278. <div class="layui-menu-body-title">
  279. <a href="laydate.html" tppabs="http://www.layui.com/doc/modules/laydate.html">
  280. <span>日期与时间选择 </span>
  281. <span class="layui-font-12 layui-font-gray">laydate</span>
  282. </a>
  283. </div>
  284. </li>
  285. <li class="">
  286. <div class="layui-menu-body-title">
  287. <a href="laypage.html" tppabs="http://www.layui.com/doc/modules/laypage.html">
  288. <span>分页 </span>
  289. <span class="layui-font-12 layui-font-gray">laypage</span>
  290. </a>
  291. </div>
  292. </li>
  293. <li class="">
  294. <div class="layui-menu-body-title">
  295. <a href="laytpl.html" tppabs="http://www.layui.com/doc/modules/laytpl.html">
  296. <span>模板引擎 </span>
  297. <span class="layui-font-12 layui-font-gray">laytpl</span>
  298. </a>
  299. </div>
  300. </li>
  301. <li class="">
  302. <div class="layui-menu-body-title">
  303. <a href="table.html" tppabs="http://www.layui.com/doc/modules/table.html">
  304. <span>数据表格 </span>
  305. <span class="layui-font-12 layui-font-gray">table</span>
  306. </a>
  307. </div>
  308. </li>
  309. <li class="layui-menu-item-checked2">
  310. <div class="layui-menu-body-title">
  311. <a href="form.html" tppabs="http://www.layui.com/doc/modules/form.html">
  312. <span>表单 </span>
  313. <span class="layui-font-12 layui-font-gray">form</span>
  314. </a>
  315. </div>
  316. </li>
  317. <li class="">
  318. <div class="layui-menu-body-title">
  319. <a href="upload.html" tppabs="http://www.layui.com/doc/modules/upload.html">
  320. <span>文件上传 </span>
  321. <span class="layui-font-12 layui-font-gray">upload</span>
  322. </a>
  323. </div>
  324. </li>
  325. <li class="">
  326. <div class="layui-menu-body-title">
  327. <a href="dropdown.html" tppabs="http://www.layui.com/doc/modules/dropdown.html">
  328. <span>下拉菜单 </span>
  329. <span class="layui-font-12 layui-font-gray">dropdown</span>
  330. <span class="layui-badge-dot"></span>
  331. </a>
  332. </div>
  333. </li>
  334. <li class="">
  335. <div class="layui-menu-body-title">
  336. <a href="transfer.html" tppabs="http://www.layui.com/doc/modules/transfer.html">
  337. <span>穿梭框 </span>
  338. <span class="layui-font-12 layui-font-gray">transfer</span>
  339. </a>
  340. </div>
  341. </li>
  342. <li class="">
  343. <div class="layui-menu-body-title">
  344. <a href="tree.html" tppabs="http://www.layui.com/doc/modules/tree.html">
  345. <span>树形组件 </span>
  346. <span class="layui-font-12 layui-font-gray">tree</span>
  347. </a>
  348. </div>
  349. </li>
  350. <li class="">
  351. <div class="layui-menu-body-title">
  352. <a href="colorpicker.html" tppabs="http://www.layui.com/doc/modules/colorpicker.html">
  353. <span>颜色选择器 </span>
  354. <span class="layui-font-12 layui-font-gray">colorpicker</span>
  355. </a>
  356. </div>
  357. </li>
  358. <li class="">
  359. <div class="layui-menu-body-title">
  360. <a href="element.html" tppabs="http://www.layui.com/doc/modules/element.html">
  361. <span>常用元素操作 </span>
  362. <span class="layui-font-12 layui-font-gray">element</span>
  363. </a>
  364. </div>
  365. </li>
  366. <li class="">
  367. <div class="layui-menu-body-title">
  368. <a href="slider.html" tppabs="http://www.layui.com/doc/modules/slider.html">
  369. <span>滑块 </span>
  370. <span class="layui-font-12 layui-font-gray">slider</span>
  371. </a>
  372. </div>
  373. </li>
  374. <li class="">
  375. <div class="layui-menu-body-title">
  376. <a href="rate.html" tppabs="http://www.layui.com/doc/modules/rate.html">
  377. <span>评分 </span>
  378. <span class="layui-font-12 layui-font-gray">rate</span>
  379. </a>
  380. </div>
  381. </li>
  382. <li class="">
  383. <div class="layui-menu-body-title">
  384. <a href="carousel.html" tppabs="http://www.layui.com/doc/modules/carousel.html">
  385. <span>轮播 </span>
  386. <span class="layui-font-12 layui-font-gray">carousel</span>
  387. </a>
  388. </div>
  389. </li>
  390. <li class="">
  391. <div class="layui-menu-body-title">
  392. <a href="layedit.html" tppabs="http://www.layui.com/doc/modules/layedit.html">
  393. <span>富文本编辑器 </span>
  394. <span class="layui-font-12 layui-font-gray">layedit</span>
  395. </a>
  396. </div>
  397. </li>
  398. <li class="">
  399. <div class="layui-menu-body-title">
  400. <a href="flow.html" tppabs="http://www.layui.com/doc/modules/flow.html">
  401. <span>流加载 </span>
  402. <span class="layui-font-12 layui-font-gray">flow</span>
  403. </a>
  404. </div>
  405. </li>
  406. <li class="">
  407. <div class="layui-menu-body-title">
  408. <a href="util.html" tppabs="http://www.layui.com/doc/modules/util.html">
  409. <span>工具组件 </span>
  410. <span class="layui-font-12 layui-font-gray">util</span>
  411. </a>
  412. </div>
  413. </li>
  414. <li class="">
  415. <div class="layui-menu-body-title">
  416. <a href="code.html" tppabs="http://www.layui.com/doc/modules/code.html">
  417. <span>代码高亮显示 </span>
  418. <span class="layui-font-12 layui-font-gray">code</span>
  419. </a>
  420. </div>
  421. </li>
  422. </ul>
  423. </li>
  424. </ul>
  425. </div>
  426. <div class="layui-hide-v"> - </div>
  427. </div>
  428. <div class="layui-col-md9 site-content">
  429. <h1 class="site-h1"><i class="layui-icon">&#xe63c;</i> 表单模块文档 - layui.form</h1>
  430. <blockquote class="site-text layui-elem-quote">
  431. 我们通常会在最常用的模块上耗费更多的精力,用尽可能简单的方式诠释 layui 所带来的便捷性。显而易见,form 是我们非常看重的一块。于是它试图用一贯极简的姿态,去捕获你对它的深深青睐。寄托在原始表单元素上的属性设定,及其全自动的初始渲染,和基于事件驱动的接口书写方式,会让你觉得,传统模式下的组件调用形式,也可以是那样的优雅、简单。然而文字的陈述始终是苍白的,所以用行动慢慢感受 layui.form 给你的项目带来的效率提升吧。
  432. </blockquote>
  433. <blockquote class="site-text layui-elem-quote">
  434. <p>模块加载名称:<em>form</em></p>
  435. </blockquote>
  436. <div class="site-title">
  437. <fieldset><legend><a name="use">使用</a></legend></fieldset>
  438. </div>
  439. <div class="site-text">
  440. <p> layui 针对各种表单元素做了较为全面的UI支持,你无需去书写那些 UI 结构,你只需要写 HTML 原始的 input、select、textarea 这些基本的标签即可。我们在 UI 上的渲染只要求一点,你必须给表单体系所在的父元素加上<em>class="layui-form"</em>,一切的工作都会在你加载完form模块后,自动完成。如下是一个最基本的例子:</p>
  441. <pre class="layui-code" lay-title="layui.form小例子">
  442. &lt;!DOCTYPE html>
  443. &lt;html>
  444. &lt;head>
  445. &lt;meta charset="utf-8">
  446. &lt;title>layui.form小例子&lt;/title>
  447. &lt;link rel="stylesheet" href="layui.css" media="all">
  448. &lt;/head>
  449. &lt;body>
  450. &lt;form class="layui-form"> &lt;!-- 提示:如果你不想用form,你可以换成div等任何一个普通元素 --&gt;
  451. &lt;div class="layui-form-item">
  452. &lt;label class="layui-form-label">输入框&lt;/label>
  453. &lt;div class="layui-input-block">
  454. &lt;input type="text" name="" placeholder="请输入" autocomplete="off" class="layui-input">
  455. &lt;/div>
  456. &lt;/div>
  457. &lt;div class="layui-form-item">
  458. &lt;label class="layui-form-label">下拉选择框&lt;/label>
  459. &lt;div class="layui-input-block">
  460. &lt;select name="interest" lay-filter="aihao">
  461. &lt;option value="0">写作&lt;/option>
  462. &lt;option value="1">阅读&lt;/option>
  463. &lt;/select>
  464. &lt;/div>
  465. &lt;/div>
  466. &lt;div class="layui-form-item">
  467. &lt;label class="layui-form-label">复选框&lt;/label>
  468. &lt;div class="layui-input-block">
  469. &lt;input type="checkbox" name="like[write]" title="写作">
  470. &lt;input type="checkbox" name="like[read]" title="阅读">
  471. &lt;/div>
  472. &lt;/div>
  473. &lt;div class="layui-form-item">
  474. &lt;label class="layui-form-label">开关关&lt;/label>
  475. &lt;div class="layui-input-block">
  476. &lt;input type="checkbox" lay-skin="switch">
  477. &lt;/div>
  478. &lt;/div>
  479. &lt;div class="layui-form-item">
  480. &lt;label class="layui-form-label">开关开&lt;/label>
  481. &lt;div class="layui-input-block">
  482. &lt;input type="checkbox" checked lay-skin="switch">
  483. &lt;/div>
  484. &lt;/div>
  485. &lt;div class="layui-form-item">
  486. &lt;label class="layui-form-label">单选框&lt;/label>
  487. &lt;div class="layui-input-block">
  488. &lt;input type="radio" name="sex" value="0" title="男">
  489. &lt;input type="radio" name="sex" value="1" title="女" checked>
  490. &lt;/div>
  491. &lt;/div>
  492. &lt;div class="layui-form-item layui-form-text">
  493. &lt;label class="layui-form-label">请填写描述&lt;/label>
  494. &lt;div class="layui-input-block">
  495. &lt;textarea placeholder="请输入内容" class="layui-textarea">&lt;/textarea>
  496. &lt;/div>
  497. &lt;/div>
  498. &lt;div class="layui-form-item">
  499. &lt;div class="layui-input-block">
  500. &lt;button class="layui-btn" lay-submit lay-filter="*">立即提交&lt;/button>
  501. &lt;button type="reset" class="layui-btn layui-btn-primary">重置&lt;/button>
  502. &lt;/div>
  503. &lt;/div>
  504. &lt;!-- 更多表单结构排版请移步文档左侧【页面元素-表单】一项阅览 --&gt;
  505. &lt;/form>
  506. &lt;script src="layui.js">&lt;/script>
  507. &lt;script>
  508. layui.use('form', function(){
  509. var form = layui.form;
  510. //各种基于事件的操作,下面会有进一步介绍
  511. });
  512. &lt;/script>
  513. &lt;/body>
  514. &lt;/html>
  515. </pre>
  516. <p>正如你上述看到的,你必须放入 layui 所<em>规范的元素结构</em>,form 模块才会对其进行重置渲染。值得注意的是,在具体的每一块表单元素中,你仍是像往日一样写 input 等标签即可。另外,我们对我们所规范的结构进行了响应式的支持,而针对一些不同的表单排版,比如行内表单,你也只需要设定我们所定义好的 class 即可。关于这一块,你可以移步页面元素的表单文档中做详细了解。而事实上你的大部分焦点可能也在那里,但当前这篇文档主要还是介绍 form 整体模块。</p>
  517. </div>
  518. <div class="site-title">
  519. <fieldset><legend><a name="render">更新渲染</a></legend></fieldset>
  520. </div>
  521. <div class="site-text">
  522. <p>有些时候,你的有些表单元素可能是动态插入的。这时 form 模块 的自动化渲染是会对其失效的。虽然我们没有双向绑定机制(因为我们叫经典模块化框架,<em>偷笑.gif</em>) 但没有关系,你只需要执行 <em>form.render(type, filter);</em> 方法即可。</p>
  523. <p>第一个参数:type,为表单的 type 类型,可选。默认对全部类型的表单进行一次更新。可局部刷新的 type 如下表:</p>
  524. <table class="layui-table">
  525. <thead>
  526. <tr>
  527. <th>参数(type)值</th>
  528. <th>描述</th>
  529. </tr>
  530. </thead>
  531. <tbody>
  532. <tr>
  533. <td>select</td>
  534. <td>刷新select选择框渲染</td>
  535. </tr>
  536. <tr>
  537. <td>checkbox</td>
  538. <td>刷新checkbox复选框(含开关)渲染</td>
  539. </tr>
  540. <tr>
  541. <td>radio</td>
  542. <td>刷新radio单选框框渲染</td>
  543. </tr>
  544. </tbody>
  545. </table>
  546. <pre class="layui-code" lay-title="例子">
  547. form.render(); //更新全部
  548. form.render('select'); //刷新select选择框渲染
  549. //……
  550. </pre>
  551. <p>第二个参数:filter,为 <em>class="layui-form"</em> 所在元素的 <em>lay-filter=""</em> 的值。你可以借助该参数,对表单完成局部更新。</p>
  552. <pre class="layui-code" lay-title="例子">
  553. 【HTML】
  554. &lt;div class=&quot;layui-form&quot; lay-filter=&quot;test1&quot;&gt;
  555. &lt;/div&gt;
  556. &lt;div class=&quot;layui-form&quot; lay-filter=&quot;test2&quot;&gt;
  557. &lt;/div&gt;
  558. 【JavaScript】
  559. form.render(null, 'test1'); //更新 lay-filter="test1" 所在容器内的全部表单状态
  560. form.render('select', 'test2'); //更新 lay-filter="test2" 所在容器内的全部 select 状态
  561. //……
  562. </pre>
  563. </div>
  564. <div class="site-title">
  565. <fieldset><legend><a name="attr">预设元素属性</a></legend></fieldset>
  566. </div>
  567. <div class="site-text">
  568. <p>事实上在使用表单时,你的一半精力可能会在元素本身上。所以我们把一些基础属性的配置恰恰安放在了标签本身上。如:</p>
  569. <pre class="layui-code">
  570. &lt;input type="text" lay-verify="email">
  571. &lt;input type="checkbox" checked lay-skin="switch" lay-filter="encrypt" title="是否加密">
  572. &lt;button lay-submit>提交&lt;/button>
  573. </pre>
  574. <p>上述的<em>lay-verify</em>、<em>lay-skin</em>、<em>lay-filter</em>、<em>lay-submit</em>神马的都是我们所说的预设的元素属性,他们可以使得一些交互操作交由form模块内部、或者你来借助form提供的JS接口精确控制。目前我们可支持的属性如下表所示:</p>
  575. <table class="layui-table">
  576. <thead>
  577. <tr>
  578. <th style="width: 80px;">属性名</th>
  579. <th style="width: 150px;">属性值</th>
  580. <th>说明</th>
  581. </tr>
  582. </thead>
  583. <tbody>
  584. <tr>
  585. <td>title</td>
  586. <td>任意字符</td>
  587. <td>设定元素名称,一般用于checkbox、radio框</td>
  588. </tr>
  589. <tr>
  590. <td>lay-skin</td>
  591. <td>
  592. switch(开关风格)
  593. primary(原始风格)
  594. </td>
  595. <td>定义元素的风格,目前只对 <em>checkbox</em> 元素有效,可将其转变为开关样式</td>
  596. </tr>
  597. <tr>
  598. <td>lay-ignore</td>
  599. <td>任意字符或不设值</td>
  600. <td>是否忽略元素美化处理。设置后,将不会对该元素进行初始化渲染,即保留系统风格</td>
  601. </tr>
  602. <tr>
  603. <td>lay-filter</td>
  604. <td>任意字符</td>
  605. <td>事件过滤器,主要用于事件的精确匹配,跟选择器是比较类似的。其实它并不私属于form模块,它在 layui 的很多基于事件的接口中都会应用到。</td>
  606. </tr>
  607. <tr>
  608. <td>lay-verify</td>
  609. <td>required(必填项)<br>phone(手机号)<br>email(邮箱)<br>url(网址)<br>number(数字)<br>date(日期)<br>identity(身份证)<br>自定义值</td>
  610. <td>同时支持多条规则的验证,格式:<em>lay-verify="验证A|验证B"</em>
  611. <br>如:<em>lay-verify="required|phone|number"</em>
  612. <br><br>另外,除了我们内置的校验规则,你还可以给他设定任意的值,比如lay-verify="pass",那么你就需要借助form.verify()方法对pass进行一个校验规则的定义。<a href="#verify">详见表单验证</a></td>
  613. </tr>
  614. <tr>
  615. <td>lay-verType</td>
  616. <td>
  617. tips(吸附层)<br>alert(对话框)<br>msg(默认)
  618. </td>
  619. <td>用于定义异常提示层模式。</td>
  620. </tr>
  621. <tr>
  622. <td>lay-reqText</td>
  623. <td>
  624. 任意字符
  625. </td>
  626. <td>
  627. 用于自定义必填项(即设定了 lay-verify="required" 的表单)的提示文本
  628. <br> 注意:<em>该功能为 layui 2.5.0 新增</em>
  629. </td>
  630. </tr>
  631. <tr>
  632. <td>lay-submit</td>
  633. <td>无需填写值</td>
  634. <td>绑定触发提交的元素,如button</td>
  635. </tr>
  636. </tbody>
  637. </table>
  638. </div>
  639. <div class="site-title">
  640. <fieldset><legend><a name="on">事件触发</a></legend></fieldset>
  641. </div>
  642. <div class="site-text">
  643. <p>语法:<a>form.on('event(过滤器值)', callback);</a></p>
  644. <p>form模块在 layui 事件机制中注册了专属事件,所以当你使用layui.onevent()自定义模块事件时,请勿占用form名。form支持的事件如下:</p>
  645. <table class="layui-table">
  646. <thead>
  647. <tr>
  648. <th>event</th>
  649. <th>描述</th>
  650. </tr>
  651. </thead>
  652. <tbody>
  653. <tr>
  654. <td>select</td>
  655. <td>触发select下拉选择事件</td>
  656. </tr>
  657. <tr>
  658. <td>checkbox</td>
  659. <td>触发checkbox复选框勾选事件</td>
  660. </tr>
  661. <tr>
  662. <td>switch</td>
  663. <td>触发checkbox复选框开关事件</td>
  664. </tr>
  665. <tr>
  666. <td>radio</td>
  667. <td>触发radio单选框事件</td>
  668. </tr>
  669. <tr>
  670. <td>submit</td>
  671. <td>触发表单提交事件</td>
  672. </tr>
  673. </tbody>
  674. </table>
  675. <p>默认情况下,事件所触发的是全部的form模块元素,但如果你只想触发某一个元素,使用事件过滤器即可。<br>如:<em>&lt;select lay-filter="test">&lt;/select></em></p>
  676. <pre class="layui-code">
  677. form.on('select(test)', function(data){
  678. console.log(data);
  679. });
  680. </pre>
  681. </div>
  682. <div class="site-title">
  683. <fieldset><legend><a name="onselect">触发select选择</a></legend></fieldset>
  684. </div>
  685. <div class="site-text">
  686. <p>下拉选择框被选中时触发,回调函数返回一个object参数,携带两个成员:</p>
  687. <pre class="layui-code" lay-title="语法">
  688. form.on('select(filter)', function(data){
  689. console.log(data.elem); //得到select原始DOM对象
  690. console.log(data.value); //得到被选中的值
  691. console.log(data.othis); //得到美化后的DOM对象
  692. });
  693. </pre>
  694. <p>请注意:如果你想触发所有的select,去掉过滤器<em>(filter)</em>即可。下面将不再对此进行备注。</p>
  695. </div>
  696. <div class="site-title">
  697. <fieldset><legend><a name="oncheckbox">触发checkbox复选</a></legend></fieldset>
  698. </div>
  699. <div class="site-text">
  700. <p>复选框点击勾选时触发,回调函数返回一个object参数,携带两个成员:</p>
  701. <pre class="layui-code" lay-title="语法">
  702. form.on('checkbox(filter)', function(data){
  703. console.log(data.elem); //得到checkbox原始DOM对象
  704. console.log(data.elem.checked); //是否被选中,true或者false
  705. console.log(data.value); //复选框value值,也可以通过data.elem.value得到
  706. console.log(data.othis); //得到美化后的DOM对象
  707. });
  708. </pre>
  709. </div>
  710. <div class="site-title">
  711. <fieldset><legend><a name="onswitch">触发switch开关</a></legend></fieldset>
  712. </div>
  713. <div class="site-text">
  714. <p>开关被点击时触发,回调函数返回一个object参数,携带两个成员:</p>
  715. <pre class="layui-code" lay-title="语法">
  716. form.on('switch(filter)', function(data){
  717. console.log(data.elem); //得到checkbox原始DOM对象
  718. console.log(data.elem.checked); //开关是否开启,true或者false
  719. console.log(data.value); //开关value值,也可以通过data.elem.value得到
  720. console.log(data.othis); //得到美化后的DOM对象
  721. });
  722. </pre>
  723. </div>
  724. <div class="site-title">
  725. <fieldset><legend><a name="onradio">触发radio单选</a></legend></fieldset>
  726. </div>
  727. <div class="site-text">
  728. <p>radio单选框被点击时触发,回调函数返回一个object参数,携带两个成员:</p>
  729. <pre class="layui-code" lay-title="语法">
  730. form.on('radio(filter)', function(data){
  731. console.log(data.elem); //得到radio原始DOM对象
  732. console.log(data.value); //被点击的radio的value值
  733. });
  734. </pre>
  735. </div>
  736. <div class="site-title">
  737. <fieldset><legend><a name="onsubmit">触发submit提交</a></legend></fieldset>
  738. </div>
  739. <div class="site-text">
  740. <p>按钮点击或者表单被执行提交时触发,其中回调函数只有在验证全部通过后才会进入,回调返回三个成员:</p>
  741. <pre class="layui-code" lay-title="语法">
  742. form.on('submit(*)', function(data){
  743. console.log(data.elem) //被执行事件的元素DOM对象,一般为button对象
  744. console.log(data.form) //被执行提交的form对象,一般在存在form标签时才会返回
  745. console.log(data.field) //当前容器的全部表单字段,名值对形式:{name: value}
  746. return false; //阻止表单跳转。如果需要表单跳转,去掉这段即可。
  747. });
  748. </pre>
  749. <p>再次温馨提示:上述的<em>submit(*)</em>中的 <em>*</em> 号为事件过滤器的值,是在你绑定执行提交的元素时设定的,如:</p>
  750. <pre class="layui-code">
  751. &lt;button lay-submit lay-filter="*">提交&lt;/button>
  752. </pre>
  753. <p>你可以把*号换成任意的值,如:<em>lay-filter="go"</em>,但触发事件时也要改成 <em>form.on('submit(go)', callback);</em> </p>
  754. </div>
  755. <div class="site-title">
  756. <fieldset><legend><a name="val">表单赋值 / 取值</a></legend></fieldset>
  757. </div>
  758. <div class="site-text">
  759. <p>语法:<em>form.val('filter', object);</em></p>
  760. <p>
  761. 用于给指定表单集合的元素赋值和取值。如果 object 参数存在,则为赋值;如果 object 参数不存在,则为取值。
  762. <br>注:<span style="color: #FF5722;">其中「取值」功能为 layui 2.5.5 开始新增</span>
  763. </p>
  764. <pre class="layui-code">
  765. //给表单赋值
  766. form.val("formTest", { //formTest 即 class="layui-form" 所在元素属性 lay-filter="" 对应的值
  767. "username": "贤心" // "name": "value"
  768. ,"sex": "女"
  769. ,"auth": 3
  770. ,"check[write]": true
  771. ,"open": false
  772. ,"desc": "我爱layui"
  773. });
  774. //获取表单区域所有值
  775. var data1 = form.val("formTest");
  776. </pre>
  777. <p>第二个参数中的键值是表单元素对应的 <em>name</em> 和 <em>value</em>。</p>
  778. </div>
  779. <div class="site-title">
  780. <fieldset><legend><a name="verify">表单验证</a></legend></fieldset>
  781. </div>
  782. <div class="site-text">
  783. <p>我们对表单的验证进行了非常巧妙的支持,大多数时候你只需要在表单元素上加上 <em>lay-verify=""</em> 属性值即可。如:</p>
  784. <pre class="layui-code">
  785. &lt;input type="text" lay-verify="email">
  786. 还同时支持多条规则的验证,如下:
  787. &lt;input type="text" lay-verify="required|phone|number">
  788. </pre>
  789. <p>
  790. 上述对输入框定义了一个邮箱规则的校验,它会在 form 模块内部完成。目前我们内置的校验支持见上文的:<a href="#attr">预设元素属性</a>
  791. </p>
  792. <p>除了内置的校验规则外,你还可以自定义验证规则,通常对于比较复杂的校验,这是非常有必要的。</p>
  793. <pre class="layui-code" lay-title="语法">
  794. form.verify({
  795. username: function(value, item){ //<em>value:表单的值、item:表单的DOM对象</em>
  796. if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){
  797. return '用户名不能有特殊字符';
  798. }
  799. if(/(^\_)|(\__)|(\_+$)/.test(value)){
  800. return '用户名首尾不能出现下划线\'_\'';
  801. }
  802. if(/^\d+\d+\d$/.test(value)){
  803. return '用户名不能全为数字';
  804. }
  805. //如果不想自动弹出默认提示框,可以直接返回 true,这时你可以通过其他任意方式提示(v2.5.7 新增)
  806. if(value === 'xxx'){
  807. alert('用户名不能为敏感词');
  808. return true;
  809. }
  810. }
  811. //我们既支持上述函数式的方式,也支持下述数组的形式
  812. //数组的两个值分别代表:[正则匹配、匹配不符时的提示文字]
  813. ,pass: [
  814. /^[\S]{6,12}$/
  815. ,'密码必须6到12位,且不能出现空格'
  816. ]
  817. });
  818. </pre>
  819. <p>当你自定义了类似上面的验证规则后,你只需要把 key 赋值给输入框的 <em>lay-verify</em> 属性即可:</p>
  820. <pre class="layui-code">
  821. &lt;input type="text" lay-verify="username" placeholder="请输入用户名">
  822. &lt;input type="password" lay-verify="pass" placeholder="请输入密码">
  823. </pre>
  824. </div>
  825. <div class="site-title">
  826. <fieldset><legend><a name="other">再次温馨提示一下</a></legend></fieldset>
  827. </div>
  828. <div class="site-text">
  829. <p>针对一些不同的表单排版,比如行内表单、整体表单风格、按钮风格等等,请移步到文档导航左侧【<em>页面元素</em>】下的指定分类即可。</p>
  830. </div>
  831. <div class="layui-elem-quote">
  832. <p>layui - 在每一个细节中,用心与你沟通</p>
  833. </div>
  834. </div>
  835. </div>
  836. <div class="layui-footer footer footer-doc">
  837. <p>
  838. Copyright &copy; 2021 <a href="../../index.html" tppabs="http://www.layui.com/">「本站仅为 layui 文档保留的镜像站点,与官方无关」</a> MIT Licensed</p>
  839. <p>
  840. <a href="../../about/disclaimer.html" tppabs="http://www.layui.com/about/disclaimer.html" target="_blank">免责声明</a>
  841. <a href="../../about/relatedlinks.html" tppabs="http://www.layui.com/about/relatedlinks.html" target="_blank">友链</a>
  842. <a href="javascript:;" site-event="weixinmp">公众号</a>
  843. </p>
  844. </div>
  845. <script>
  846. window.global = {
  847. pageType: 'doc'
  848. ,preview: function(){
  849. var preview = document.getElementById('LAY_preview');
  850. return preview ? preview.innerHTML : '';
  851. }()
  852. };
  853. </script>
  854. <div class="site-tree-mobile layui-hide">
  855. <i class="layui-icon layui-icon-spread-left"></i>
  856. </div>
  857. <div class="site-mobile-shade"></div>
  858. <script src="/public/layui/dist/layui.js" tppabs="http://res.layui.com/layui/dist/layui.js?t=1632428048355" charset="utf-8"></script>
  859. <script>
  860. layui.config({
  861. base: '..//public/static/lay/modules/layui/'
  862. ,version: '1632428048355'
  863. }).use('global');
  864. </script>
  865. </body>
  866. </html>