layer.html 70 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>镜像站@layer弹层组件开发文档 - 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 id="L_layerDebug" style="display: none;"><a href="javascript:;" style="color: #01AAED;"><cite>在线调试</cite></a></li>
  61. <li><a href="#base"><cite>基础参数</cite></a></li>
  62. <ul style="margin-left: 15px;">
  63. <li><a href="#type">type<em>层类型</em></a></li>
  64. <li><a href="#title">title<em>标题</em></a></li>
  65. <li><a href="#content">content<em>内容</em></a></li>
  66. <li><a href="#skin">skin<em>皮肤</em></a></li>
  67. <li><a href="#area">area<em>宽高</em></a></li>
  68. <li><a href="#offset">offset<em>坐标</em></a></li>
  69. <li><a href="#icon">icon<em>提示图标</em></a></li>
  70. <li><a href="#btn">btn<em>提示按钮</em></a></li>
  71. <li><a href="#btnAlign">btnAlign<em>按钮排列</em></a></li>
  72. <li><a href="#closeBtn">closeBtn<em>右上关闭</em></a></li>
  73. <li><a href="#shade">shade<em>遮罩</em></a></li>
  74. <li><a href="#shadeClose">shadeClose</a></li>
  75. <li><a href="#time">time<em>自动关闭</em></a></li>
  76. <li><a href="#id">id<em>唯一id</em></a></li>
  77. <li><a href="#anim">anim<em>动画</em></a> </li>
  78. <li><a href="#isOutAnim">isOutAnim<em>关闭动画</em></a> </li>
  79. <li><a href="#maxmin">maxmin<em>最大小化</em></a></li>
  80. <li><a href="#fixed">fixed<em>是否固定</em></a></li>
  81. <li><a href="#resize">resize<em>是否允许拉伸</em></a></li>
  82. <li><a href="#resizing">resizing<em>正在拉伸</em></a></li>
  83. <li><a href="#scrollbar">scrollbar<em>屏蔽滚动</em></a></li>
  84. <li><a href="#maxWidth">maxWidth<em>最大宽</em></a></li>
  85. <li><a href="#maxHeight">maxHeight<em>最大高</em></a></li>
  86. <li><a href="#zIndex">zIndex<em>层叠值</em></a></li>
  87. <li><a href="#move">move<em>拖拽元素</em></a></li>
  88. <li><a href="#moveOut">moveOut<em>拖出</em></a></li>
  89. <li><a href="#moveEnd">moveEnd<em>回调</em></a></li>
  90. <li><a href="#tips">tips<em>Tips参数</em></a></li>
  91. <li><a href="#tipsMore">tipsMore<em>允许多tips</em></a> </li>
  92. <li><a href="#success">success<em>弹出后回调</em></a> </li>
  93. <li><a href="#yes">yes<em>确定回调</em></a> </li>
  94. <li><a href="#cancel">cancel<em>关闭回调</em></a> </li>
  95. <li><a href="#end">end<em>销毁后回调</em></a> </li>
  96. <li><a href="#full">full/min/restore</a> </li>
  97. <li><a href="#minStack">minStack<em>最小化堆叠</em></a></li>
  98. </ul>
  99. <li>内置方法</li>
  100. <ul style="margin-left: 15px;">
  101. <li><a href="#layer.config">config<em>全局设置</em></a></li>
  102. <li><a href="#layer.ready">ready<em>就绪</em></a></li>
  103. <li><a href="#layer.open">open<em>核心方法</em></a></li>
  104. <li><a href="#layer.alert">alert<em>弹框</em></a></li>
  105. <li><a href="#layer.confirm">confirm<em>询问</em></a></li>
  106. <li><a href="#layer.msg">msg<em>提示</em></a></li>
  107. <li><a href="#layer.load">load<em>加载</em></a></li>
  108. <li><a href="#layer.tips">tips<em>吸附</em></a></li>
  109. <li><a href="#layer.close">close<em>关闭层</em></a></li>
  110. <li><a href="#layer.closeAll">closeAll<em>关闭全部</em></a></li>
  111. <li><a href="#layer.style">style</a></li>
  112. <li><a href="#layer.title">title<em>重置标题</em></a></li>
  113. <li><a href="#layer.getChildFrame">getChildFrame</a></li>
  114. <li><a href="#layer.getFrameIndex">getFrameIndex</a></li>
  115. <li><a href="#layer.iframeAuto">iframeAuto</a></li>
  116. <li><a href="#layer.iframeSrc">iframeSrc</a></li>
  117. <li><a href="#layer.setTop">setTop<em>多层置顶</em></a></li>
  118. <li><a href="#layer.full">full/min/restore</a></li>
  119. </ul>
  120. <li>其他内置层</li>
  121. <ul style="margin-left: 15px;">
  122. <li><a href="#layer.prompt">prompt<em>输入层</em></a></li>
  123. <li><a href="#layer.tab">tab<em>选项卡层</em></a></li>
  124. <li><a href="#layer.photos">photos<em>图片层</em></a></li>
  125. </ul>
  126. </ul>
  127. <div class="layui-container layui-row">
  128. <div class="layui-col-md3">
  129. <div class="layui-panel site-menu">
  130. <ul class="layui-menu layui-menu-lg">
  131. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  132. <div class="layui-menu-body-title">
  133. 基础说明
  134. </div>
  135. <hr>
  136. <ul>
  137. <li class="">
  138. <div class="layui-menu-body-title">
  139. <a href="../index.html" tppabs="http://www.layui.com/doc/">
  140. <span>开始使用 </span>
  141. <span class="layui-font-12 layui-font-gray">Getting Started</span>
  142. </a>
  143. </div>
  144. </li>
  145. <li class="">
  146. <div class="layui-menu-body-title">
  147. <a href="../base/infrastructure.html" tppabs="http://www.layui.com/doc/base/infrastructure.html">
  148. <span>底层方法 </span>
  149. <span class="layui-font-12 layui-font-gray">基础支撑</span>
  150. </a>
  151. </div>
  152. </li>
  153. <li class="">
  154. <div class="layui-menu-body-title">
  155. <a href="../base/element.html" tppabs="http://www.layui.com/doc/base/element.html">
  156. <span>页面元素 </span>
  157. <span class="layui-font-12 layui-font-gray">规范 公共类 属性</span>
  158. </a>
  159. </div>
  160. </li>
  161. <li class="">
  162. <div class="layui-menu-body-title">
  163. <a href="../base/modules.html" tppabs="http://www.layui.com/doc/base/modules.html">
  164. <span>模块规范 </span>
  165. <span class="layui-font-12 layui-font-gray">使用 扩展</span>
  166. </a>
  167. </div>
  168. </li>
  169. <li class="">
  170. <div class="layui-menu-body-title">
  171. <a href="../base/faq.html" tppabs="http://www.layui.com/doc/base/faq.html">
  172. <span>常见问题 </span>
  173. <span class="layui-font-12 layui-font-gray">FAQ</span>
  174. </a>
  175. </div>
  176. </li>
  177. <li class="">
  178. <div class="layui-menu-body-title">
  179. <a href="../base/changelog.html" tppabs="http://www.layui.com/doc/base/changelog.html">
  180. <span>更新日志 </span>
  181. <span class="layui-font-12 layui-font-gray">changelog</span>
  182. <span class="layui-badge-dot"></span>
  183. </a>
  184. </div>
  185. </li>
  186. </ul>
  187. </li>
  188. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  189. <div class="layui-menu-body-title">
  190. 页面元素
  191. </div>
  192. <hr>
  193. <ul>
  194. <li class="">
  195. <div class="layui-menu-body-title">
  196. <a href="../element/layout.html" tppabs="http://www.layui.com/doc/element/layout.html">
  197. <span>布局 </span>
  198. <span class="layui-font-12 layui-font-gray">栅格 后台管理布局</span>
  199. </a>
  200. </div>
  201. </li>
  202. <li class="">
  203. <div class="layui-menu-body-title">
  204. <a href="../element/color.html" tppabs="http://www.layui.com/doc/element/color.html">
  205. <span>颜色 </span>
  206. <span class="layui-font-12 layui-font-gray">主色调 颜色搭配</span>
  207. </a>
  208. </div>
  209. </li>
  210. <li class="">
  211. <div class="layui-menu-body-title">
  212. <a href="../element/icon.html" tppabs="http://www.layui.com/doc/element/icon.html">
  213. <span>图标 </span>
  214. <span class="layui-font-12 layui-font-gray">iconfont 字体图标</span>
  215. </a>
  216. </div>
  217. </li>
  218. <li class="">
  219. <div class="layui-menu-body-title">
  220. <a href="../element/anim.html" tppabs="http://www.layui.com/doc/element/anim.html">
  221. <span>动画 </span>
  222. <span class="layui-font-12 layui-font-gray">内置 CSS3 动画</span>
  223. </a>
  224. </div>
  225. </li>
  226. <li class="">
  227. <div class="layui-menu-body-title">
  228. <a href="../element/button.html" tppabs="http://www.layui.com/doc/element/button.html">
  229. <span>按钮 </span>
  230. <span class="layui-font-12 layui-font-gray">button</span>
  231. </a>
  232. </div>
  233. </li>
  234. <li class="">
  235. <div class="layui-menu-body-title">
  236. <a href="../element/form.html" tppabs="http://www.layui.com/doc/element/form.html">
  237. <span>表单 </span>
  238. <span class="layui-font-12 layui-font-gray">form 元素集合</span>
  239. </a>
  240. </div>
  241. </li>
  242. <li class="">
  243. <div class="layui-menu-body-title">
  244. <a href="../element/nav.html" tppabs="http://www.layui.com/doc/element/nav.html">
  245. <span>导航 </span>
  246. <span class="layui-font-12 layui-font-gray">nav 面包屑</span>
  247. </a>
  248. </div>
  249. </li>
  250. <li class="">
  251. <div class="layui-menu-body-title">
  252. <a href="../element/menu.html" tppabs="http://www.layui.com/doc/element/menu.html">
  253. <span>菜单 </span>
  254. <span class="layui-font-12 layui-font-gray">menu 基础菜单</span>
  255. <span class="layui-badge-dot"></span>
  256. </a>
  257. </div>
  258. </li>
  259. <li class="">
  260. <div class="layui-menu-body-title">
  261. <a href="../element/tab.html" tppabs="http://www.layui.com/doc/element/tab.html">
  262. <span>选项卡 </span>
  263. <span class="layui-font-12 layui-font-gray">Tabs 切换</span>
  264. </a>
  265. </div>
  266. </li>
  267. <li class="">
  268. <div class="layui-menu-body-title">
  269. <a href="../element/progress.html" tppabs="http://www.layui.com/doc/element/progress.html">
  270. <span>进度条 </span>
  271. <span class="layui-font-12 layui-font-gray">progress</span>
  272. </a>
  273. </div>
  274. </li>
  275. <li class="">
  276. <div class="layui-menu-body-title">
  277. <a href="../element/panel.html" tppabs="http://www.layui.com/doc/element/panel.html">
  278. <span>面板 </span>
  279. <span class="layui-font-12 layui-font-gray">panel 卡片 折叠</span>
  280. </a>
  281. </div>
  282. </li>
  283. <li class="">
  284. <div class="layui-menu-body-title">
  285. <a href="../element/table.html" tppabs="http://www.layui.com/doc/element/table.html">
  286. <span>表格 </span>
  287. <span class="layui-font-12 layui-font-gray">静态 table</span>
  288. </a>
  289. </div>
  290. </li>
  291. <li class="">
  292. <div class="layui-menu-body-title">
  293. <a href="../element/badge.html" tppabs="http://www.layui.com/doc/element/badge.html">
  294. <span>徽章 </span>
  295. <span class="layui-font-12 layui-font-gray">小圆点 小边框</span>
  296. </a>
  297. </div>
  298. </li>
  299. <li class="">
  300. <div class="layui-menu-body-title">
  301. <a href="../element/timeline.html" tppabs="http://www.layui.com/doc/element/timeline.html">
  302. <span>时间线 </span>
  303. <span class="layui-font-12 layui-font-gray">timeline</span>
  304. </a>
  305. </div>
  306. </li>
  307. <li class="">
  308. <div class="layui-menu-body-title">
  309. <a href="../element/auxiliar.html" tppabs="http://www.layui.com/doc/element/auxiliar.html">
  310. <span>辅助 </span>
  311. <span class="layui-font-12 layui-font-gray">引用 字段集 横线等</span>
  312. </a>
  313. </div>
  314. </li>
  315. </ul>
  316. </li>
  317. <li class="layui-menu-item-group" lay-options="{type: 'group', isAllowSpread: true}">
  318. <div class="layui-menu-body-title">
  319. 内置模块
  320. </div>
  321. <hr>
  322. <ul>
  323. <li class="layui-menu-item-checked2">
  324. <div class="layui-menu-body-title">
  325. <a href="layer.html" tppabs="http://www.layui.com/doc/modules/layer.html">
  326. <span>弹出层 </span>
  327. <span class="layui-font-12 layui-font-gray">layer</span>
  328. </a>
  329. </div>
  330. </li>
  331. <li class="">
  332. <div class="layui-menu-body-title">
  333. <a href="laydate.html" tppabs="http://www.layui.com/doc/modules/laydate.html">
  334. <span>日期与时间选择 </span>
  335. <span class="layui-font-12 layui-font-gray">laydate</span>
  336. </a>
  337. </div>
  338. </li>
  339. <li class="">
  340. <div class="layui-menu-body-title">
  341. <a href="laypage.html" tppabs="http://www.layui.com/doc/modules/laypage.html">
  342. <span>分页 </span>
  343. <span class="layui-font-12 layui-font-gray">laypage</span>
  344. </a>
  345. </div>
  346. </li>
  347. <li class="">
  348. <div class="layui-menu-body-title">
  349. <a href="laytpl.html" tppabs="http://www.layui.com/doc/modules/laytpl.html">
  350. <span>模板引擎 </span>
  351. <span class="layui-font-12 layui-font-gray">laytpl</span>
  352. </a>
  353. </div>
  354. </li>
  355. <li class="">
  356. <div class="layui-menu-body-title">
  357. <a href="table.html" tppabs="http://www.layui.com/doc/modules/table.html">
  358. <span>数据表格 </span>
  359. <span class="layui-font-12 layui-font-gray">table</span>
  360. </a>
  361. </div>
  362. </li>
  363. <li class="">
  364. <div class="layui-menu-body-title">
  365. <a href="form.html" tppabs="http://www.layui.com/doc/modules/form.html">
  366. <span>表单 </span>
  367. <span class="layui-font-12 layui-font-gray">form</span>
  368. </a>
  369. </div>
  370. </li>
  371. <li class="">
  372. <div class="layui-menu-body-title">
  373. <a href="upload.html" tppabs="http://www.layui.com/doc/modules/upload.html">
  374. <span>文件上传 </span>
  375. <span class="layui-font-12 layui-font-gray">upload</span>
  376. </a>
  377. </div>
  378. </li>
  379. <li class="">
  380. <div class="layui-menu-body-title">
  381. <a href="dropdown.html" tppabs="http://www.layui.com/doc/modules/dropdown.html">
  382. <span>下拉菜单 </span>
  383. <span class="layui-font-12 layui-font-gray">dropdown</span>
  384. <span class="layui-badge-dot"></span>
  385. </a>
  386. </div>
  387. </li>
  388. <li class="">
  389. <div class="layui-menu-body-title">
  390. <a href="transfer.html" tppabs="http://www.layui.com/doc/modules/transfer.html">
  391. <span>穿梭框 </span>
  392. <span class="layui-font-12 layui-font-gray">transfer</span>
  393. </a>
  394. </div>
  395. </li>
  396. <li class="">
  397. <div class="layui-menu-body-title">
  398. <a href="tree.html" tppabs="http://www.layui.com/doc/modules/tree.html">
  399. <span>树形组件 </span>
  400. <span class="layui-font-12 layui-font-gray">tree</span>
  401. </a>
  402. </div>
  403. </li>
  404. <li class="">
  405. <div class="layui-menu-body-title">
  406. <a href="colorpicker.html" tppabs="http://www.layui.com/doc/modules/colorpicker.html">
  407. <span>颜色选择器 </span>
  408. <span class="layui-font-12 layui-font-gray">colorpicker</span>
  409. </a>
  410. </div>
  411. </li>
  412. <li class="">
  413. <div class="layui-menu-body-title">
  414. <a href="element.html" tppabs="http://www.layui.com/doc/modules/element.html">
  415. <span>常用元素操作 </span>
  416. <span class="layui-font-12 layui-font-gray">element</span>
  417. </a>
  418. </div>
  419. </li>
  420. <li class="">
  421. <div class="layui-menu-body-title">
  422. <a href="slider.html" tppabs="http://www.layui.com/doc/modules/slider.html">
  423. <span>滑块 </span>
  424. <span class="layui-font-12 layui-font-gray">slider</span>
  425. </a>
  426. </div>
  427. </li>
  428. <li class="">
  429. <div class="layui-menu-body-title">
  430. <a href="rate.html" tppabs="http://www.layui.com/doc/modules/rate.html">
  431. <span>评分 </span>
  432. <span class="layui-font-12 layui-font-gray">rate</span>
  433. </a>
  434. </div>
  435. </li>
  436. <li class="">
  437. <div class="layui-menu-body-title">
  438. <a href="carousel.html" tppabs="http://www.layui.com/doc/modules/carousel.html">
  439. <span>轮播 </span>
  440. <span class="layui-font-12 layui-font-gray">carousel</span>
  441. </a>
  442. </div>
  443. </li>
  444. <li class="">
  445. <div class="layui-menu-body-title">
  446. <a href="layedit.html" tppabs="http://www.layui.com/doc/modules/layedit.html">
  447. <span>富文本编辑器 </span>
  448. <span class="layui-font-12 layui-font-gray">layedit</span>
  449. </a>
  450. </div>
  451. </li>
  452. <li class="">
  453. <div class="layui-menu-body-title">
  454. <a href="layedit.html" tppabs="http://www.layui.com/doc/modules/layedit.html">
  455. <span>富文本编辑器 </span>
  456. <span class="layui-font-12 layui-font-gray">layedit</span>
  457. </a>
  458. </div>
  459. </li>
  460. <li class="">
  461. <div class="layui-menu-body-title">
  462. <a href="flow.html" tppabs="http://www.layui.com/doc/modules/flow.html">
  463. <span>流加载 </span>
  464. <span class="layui-font-12 layui-font-gray">flow</span>
  465. </a>
  466. </div>
  467. </li>
  468. <li class="">
  469. <div class="layui-menu-body-title">
  470. <a href="util.html" tppabs="http://www.layui.com/doc/modules/util.html">
  471. <span>工具组件 </span>
  472. <span class="layui-font-12 layui-font-gray">util</span>
  473. </a>
  474. </div>
  475. </li>
  476. <li class="">
  477. <div class="layui-menu-body-title">
  478. <a href="code.html" tppabs="http://www.layui.com/doc/modules/code.html">
  479. <span>代码高亮显示 </span>
  480. <span class="layui-font-12 layui-font-gray">code</span>
  481. </a>
  482. </div>
  483. </li>
  484. </ul>
  485. </li>
  486. </ul>
  487. </div>
  488. <div class="layui-hide-v"> - </div>
  489. </div>
  490. <div class="layui-col-md9 site-content">
  491. <h1 class="site-h1"><i class="layui-icon">&#xe638;</i> 弹层组件文档 - layui.layer</h1>
  492. <blockquote class="layui-elem-quote site-text">
  493. layer 至今仍作为 layui 的代表作,它的受众广泛并非偶然,而是这数年来的坚持、不弃的执念,将那些不屑的眼光转化为应得的尊重,不断完善和维护、不断建设和提升社区服务,在 Web 开发者的圈子里口口相传,乃至于成为今天的 layui 最强劲的源动力。目前,<em>layer </em>已然成为网页弹出层的首选交互方案,几乎随处可见。
  494. </blockquote>
  495. <blockquote class="layui-elem-quote site-text">
  496. 模块加载名称:<em>layer</em>,独立版本:<a href="http://layer.layui.com/" target="_blank">layer.layui.com</a>
  497. </blockquote>
  498. <div class="site-title">
  499. <fieldset><legend><a name="use">使用场景</a></legend></fieldset>
  500. </div>
  501. <div class="site-text">
  502. <p>由于layer可以独立使用,也可以通过Layui模块化使用。所以请按照你的实际需求来选择。</p>
  503. <table class="layui-table">
  504. <thead>
  505. <tr>
  506. <th style="width: 150px;">场景</th>
  507. <th style="width: 450px;">用前准备</th>
  508. <th>调用方式</th>
  509. </tr>
  510. </thead>
  511. <tbody>
  512. <tr>
  513. <td>1. 作为独立组件使用</td>
  514. <td>
  515. 如果你只是单独想使用 layer,你可以去 <a href="http://layer.layui.com/" target="_blank">layer</a> 独立版本官网下载组件包。你需要在你的页面引入<em>jQuery</em>1.8以上的任意版本,并引入<em>layer.js</em>。
  516. </td>
  517. <td>
  518. 通过script标签引入layer.js后,直接用即可。
  519. 参考:<a href="http://layer.layui.com/hello.html" target="_blank">快速上手</a>
  520. </td>
  521. </tr>
  522. <tr>
  523. <td>2. layui 模块化使用</td>
  524. <td>
  525. 如果你使用的是 layui,那么你直接在官网下载 layui 框架即可,无需引入 jQuery 和 layer.js,但需要引入<em>layui.css</em>和<em>layui.js</em>
  526. </td>
  527. <td>
  528. 通过<em>layui.use('layer', callback)</em>加载模块
  529. </td>
  530. </tr>
  531. <tr>
  532. </tbody>
  533. </table>
  534. <pre class="layui-code" lay-title="作为独立组件使用 layer">
  535. 引入好layer.js后,直接用即可
  536. &lt;script src="layer.js">&lt;/script>
  537. &lt;script>
  538. layer.msg('hello');
  539. &lt;/script>
  540. </pre>
  541. <pre class="layui-code" lay-title="在 layui 中使用 layer">
  542. layui.use('layer', function(){
  543. var layer = layui.layer;
  544. layer.msg('hello');
  545. });
  546. </pre>
  547. <p>除了上面有所不同,其它都完全一致。</p>
  548. </div>
  549. <div class="site-title">
  550. <fieldset><legend><a name="base">基础参数</a></legend></fieldset>
  551. </div>
  552. <div class="site-text">
  553. <p>我们提到的基础参数主要指调用方法时用到的配置项,如:<em>layer.open({content: ''})</em><em>layer.msg('', {time: 3})</em>等,其中的content和time即是基础参数,以键值形式存在,基础参数<em>可合理应用于任何层类型中</em>,您不需要所有都去配置,大多数都是可选的。而其中的layer.open、layer.msg就是内置方法。注意,从2.3开始,无需通过layer.config来加载拓展模块</p>
  554. </div>
  555. <dl>
  556. <div class="site-title"><fieldset><legend><a name="type">type</a> - 基本层类型</legend></fieldset></div>
  557. <dd class="site-text">
  558. <p><span>类型</span>:Number,<span>默认</span>:0</p>
  559. <p>layer提供了5种层类型。可传入的值有:<em>0</em>(信息框,默认)<em>1</em>(页面层)<em>2</em>(iframe层)<em>3</em>(加载层)<em>4</em>(tips层)。
  560. 若你采用<em>layer.open({type: 1})</em>方式调用,则type为必填项(信息框除外)</p>
  561. </dd>
  562. <div class="site-title"><fieldset><legend><a name="title">title</a> - 标题</legend></fieldset></div>
  563. <dd class="site-text">
  564. <p><span>类型</span>:String/Array/Boolean,<span>默认</span>:'信息'</p>
  565. <p>title支持三种类型的值,若你传入的是普通的字符串,如<em>title
  566. :'我是标题'</em>,那么只会改变标题文本;若你还需要自定义标题区域样式,那么你可以<em>title: ['文本', 'font-size:18px;']</em>,数组第二项可以写任意css样式;如果你不想显示标题栏,你可以<em>title: false</em></p>
  567. </dd>
  568. <div class="site-title"><fieldset><legend><a name="content">content</a> - 内容</legend></fieldset></div>
  569. <dd class="site-text">
  570. <p><span>类型</span>:String/DOM/Array,<span>默认</span>:''</p>
  571. <p>content可传入的值是灵活多变的,不仅可以传入普通的html内容,还可以指定DOM,更可以随着type的不同而不同。譬如:</p>
  572. <pre class="layui-code">
  573. /!*
  574. 如果是页面层
  575. */
  576. layer.open({
  577. type: 1,
  578. content: '传入任意的文本或html' //这里content是一个普通的String
  579. });
  580. layer.open({
  581. type: 1,
  582. content: $('#id') //这里content是一个DOM,注意:最好该元素要存放在body最外层,否则可能被其它的相对元素所影响
  583. });
  584. //Ajax获取
  585. $.post('url', {}, function(str){
  586. layer.open({
  587. type: 1,
  588. content: str //注意,如果str是object,那么需要字符拼接。
  589. });
  590. });
  591. /!*
  592. 如果是iframe层
  593. */
  594. layer.open({
  595. type: 2,
  596. content: 'http://sentsin.com' //这里content是一个URL,如果你不想让iframe出现滚动条,你还可以<em>content: ['http://sentsin.com', 'no']</em>
  597. });
  598. /!*
  599. 如果是用layer.open执行tips层
  600. */
  601. layer.open({
  602. type: 4,
  603. content: ['内容', '#id'] //数组第二项即吸附元素选择器或者DOM
  604. });
  605. </pre>
  606. </dd>
  607. <div class="site-title"><fieldset><legend><a name="skin">skin</a> - 样式类名</legend></fieldset></div>
  608. <dd class="site-text">
  609. <p><span>类型</span>:String,<span>默认</span>:''</p>
  610. <p>skin不仅允许你传入layer内置的样式class名,还可以传入您自定义的class名。这是一个很好的切入点,意味着你可以借助skin轻松完成不同的风格定制。目前layer内置的skin有:<em>layui-layer-lan</em><em>layui-layer-molv</em>,未来我们还会选择性地内置更多,但更推荐您自己来定义。以下是一个自定义风格的简单例子</p>
  611. <pre class="layui-code">
  612. //单个使用
  613. layer.open({
  614. skin: 'demo-class'
  615. });
  616. //全局使用。即所有弹出层都默认采用,但是单个配置skin的优先级更高
  617. layer.config({
  618. skin: 'demo-class'
  619. })
  620. //CSS
  621. body .demo-class .layui-layer-title{background:#c00; color:#fff; border: none;}
  622. body .demo-class .layui-layer-btn{border-top:1px solid #E9E7E7}
  623. body .demo-class .layui-layer-btn a{background:#333;}
  624. body .demo-class .layui-layer-btn .layui-layer-btn1{background:#999;}
  625. 加上body是为了保证优先级。你可以借助Chrome调试工具,定义更多样式控制层更多的区域。
  626. </pre>
  627. <p>你也可以<a class="layer-btn" href="http://layer.layui.com/skin.html#publish" target="_blank">去查看layer皮肤制作说明</a> </p>
  628. </dd>
  629. <div class="site-title"><fieldset><legend><a name="area">area</a> - 宽高</legend></fieldset></div>
  630. <dd class="site-text">
  631. <p><span>类型</span>:String/Array,<span>默认</span>:'auto'</p>
  632. <p>在默认状态下,layer是宽高都自适应的,但当你只想定义宽度时,你可以<em>area: '500px'</em>,高度仍然是自适应的。当你宽高都要定义时,你可以<em>area: ['500px', '300px']</em></p>
  633. </dd>
  634. <div class="site-title"><fieldset><legend><a name="offset">offset</a> - 坐标</legend></fieldset></div>
  635. <dd class="site-text">
  636. <p><span>类型</span>:String/Array,<span>默认</span>:垂直水平居中</p>
  637. <p>offset默认情况下不用设置。但如果你不想垂直水平居中,你还可以进行以下赋值:</p>
  638. <table class="layui-table">
  639. <thead>
  640. <tr>
  641. <th>值</th>
  642. <th>备注</th>
  643. </tr>
  644. </thead>
  645. <tbody>
  646. <tr>
  647. <td>offset: 'auto'</td>
  648. <td>默认坐标,即垂直水平居中</td>
  649. </tr>
  650. <tr>
  651. <td>offset: '100px'</td>
  652. <td>只定义top坐标,水平保持居中</td>
  653. </tr>
  654. <tr>
  655. <td>offset: ['100px', '50px']</td>
  656. <td>同时定义top、left坐标</td>
  657. </tr>
  658. <tr>
  659. <td>offset: 't'</td>
  660. <td>快捷设置顶部坐标</td>
  661. </tr>
  662. <tr>
  663. <td>offset: 'r'</td>
  664. <td>快捷设置右边缘坐标</td>
  665. </tr>
  666. <tr>
  667. <td>offset: 'b'</td>
  668. <td>快捷设置底部坐标</td>
  669. </tr>
  670. <tr>
  671. <td>offset: 'l'</td>
  672. <td>快捷设置左边缘坐标</td>
  673. </tr>
  674. <tr>
  675. <td>offset: 'lt'</td>
  676. <td>快捷设置左上角</td>
  677. </tr>
  678. <tr>
  679. <td>offset: 'lb'</td>
  680. <td>快捷设置左下角</td>
  681. </tr>
  682. <tr>
  683. <td>offset: 'rt'</td>
  684. <td>快捷设置右上角</td>
  685. </tr>
  686. <tr>
  687. <td>offset: 'rb'</td>
  688. <td>快捷设置右下角</td>
  689. </tr>
  690. </tbody>
  691. </table>
  692. </dd>
  693. <div class="site-title"><fieldset><legend><a name="icon">icon</a> - 图标。信息框和加载层的私有参数</legend></fieldset></div>
  694. <dd class="site-text">
  695. <p><span>类型</span>:Number,<span>默认</span>:-1(信息框)/0(加载层)</p>
  696. <p>信息框默认不显示图标。当你想显示图标时,默认皮肤可以传入<em>0-6</em>如果是加载层,可以传入<em>0-2</em>。如:</p>
  697. <pre class="layui-code">
  698. //eg1
  699. layer.alert('酷毙了', {icon: 1});
  700. //eg2
  701. layer.msg('不开心。。', {icon: 5});
  702. //eg3
  703. layer.load(1); //风格1的加载
  704. </pre>
  705. </dd>
  706. <div class="site-title"><fieldset><legend><a name="btn">btn</a> - 按钮</legend></fieldset></div>
  707. <dd class="site-text">
  708. <p><span>类型</span>:String/Array,<span>默认</span>:'确认'</p>
  709. <p>信息框模式时,btn默认是一个确认按钮,其它层类型则默认不显示,加载层和tips层则无效。当您只想自定义一个按钮时,你可以<em>btn: '我知道了'</em>,当你要定义两个按钮时,你可以<em>btn: ['yes', 'no']</em>。当然,你也可以定义更多按钮,比如:<em>btn: ['按钮1', '按钮2', '按钮3', …]</em>,按钮1的回调是yes,而从按钮2开始,则回调为btn2: function(){},以此类推。如:</p>
  710. <pre class="layui-code">
  711. //eg1
  712. layer.confirm('纳尼?', {
  713. btn: ['按钮一', '按钮二', '按钮三'] //可以无限个按钮
  714. ,btn3: function(index, layero){
  715. //按钮【按钮三】的回调
  716. }
  717. }, function(index, layero){
  718. //按钮【按钮一】的回调
  719. }, function(index){
  720. //按钮【按钮二】的回调
  721. });
  722. //eg2
  723. layer.open({
  724. content: 'test'
  725. ,btn: ['按钮一', '按钮二', '按钮三']
  726. ,yes: function(index, layero){
  727. //按钮【按钮一】的回调
  728. }
  729. ,btn2: function(index, layero){
  730. //按钮【按钮二】的回调
  731. //return false 开启该代码可禁止点击该按钮关闭
  732. }
  733. ,btn3: function(index, layero){
  734. //按钮【按钮三】的回调
  735. //return false 开启该代码可禁止点击该按钮关闭
  736. }
  737. ,cancel: function(){
  738. //右上角关闭回调
  739. //return false 开启该代码可禁止点击该按钮关闭
  740. }
  741. });
  742. </pre>
  743. </dd>
  744. <div class="site-title"><fieldset><legend><a name="btnAlign">btnAlign</a> - 按钮排列</legend></fieldset></div>
  745. <dd class="site-text">
  746. <p><span>类型</span>:String,<span>默认</span>:r</p>
  747. <p>你可以快捷定义按钮的排列位置,btnAlign的默认值为r,即右对齐。该参数可支持的赋值如下:</p>
  748. <table class="layui-table">
  749. <thead>
  750. <tr>
  751. <th>值</th>
  752. <th>备注</th>
  753. </tr>
  754. </thead>
  755. <tbody>
  756. <tr>
  757. <td>btnAlign: 'l'</td>
  758. <td>按钮左对齐</td>
  759. </tr>
  760. <tr>
  761. <td>btnAlign: 'c'</td>
  762. <td>按钮居中对齐</td>
  763. </tr>
  764. <tr>
  765. <td>btnAlign: 'r'</td>
  766. <td>按钮右对齐。默认值,不用设置</td>
  767. </tr>
  768. <tr>
  769. </tbody>
  770. </table>
  771. </dd>
  772. <div class="site-title"><fieldset><legend><a name="closeBtn">closeBtn</a> - 关闭按钮</legend></fieldset></div>
  773. <dd class="site-text">
  774. <p><span>类型</span>:String/Boolean,<span>默认</span>:1</p>
  775. <p>layer提供了两种风格的关闭按钮,可通过配置<em>1</em>和<em>2</em>来展示,如果不显示,则<em>closeBtn: 0</em></p>
  776. </dd>
  777. <div class="site-title"><fieldset><legend><a name="shade">shade</a> - 遮罩</legend></fieldset></div>
  778. <dd class="site-text">
  779. <p><span>类型</span>:String/Array/Boolean,<span>默认</span>:0.3</p>
  780. <p>即弹层外区域。默认是0.3透明度的黑色背景('#000')。如果你想定义别的颜色,可以<em>shade: [0.8, '#393D49']</em>;如果你不想显示遮罩,可以<em>shade: 0</em></p>
  781. </dd>
  782. <div class="site-title"><fieldset><legend><a name="shadeClose">shadeClose</a> - 是否点击遮罩关闭</legend></fieldset></div>
  783. <dd class="site-text">
  784. <p><span>类型</span>:Boolean,<span>默认</span>:false</p>
  785. <p>如果你的shade是存在的,那么你可以设定shadeClose来控制点击弹层外区域关闭。</p>
  786. </dd>
  787. <div class="site-title"><fieldset><legend><a name="time">time</a> - 自动关闭所需毫秒</legend></fieldset></div>
  788. <dd class="site-text">
  789. <p><span>类型</span>:Number,<span>默认</span>:0</p>
  790. <p>默认不会自动关闭。当你想自动关闭时,可以<em>time: 5000</em>,即代表5秒后自动关闭,注意单位是毫秒(1秒=1000毫秒)</p>
  791. </dd>
  792. <div class="site-title"><fieldset><legend><a name="id">id</a> - 用于控制弹层唯一标识</legend></fieldset></div>
  793. <dd class="site-text">
  794. <p><span>类型</span>:String,<span>默认</span>:空字符</p>
  795. <p>设置该值后,不管是什么类型的层,都只允许同时弹出一个。一般用于页面层和iframe层模式</p>
  796. </dd>
  797. <div class="site-title"><fieldset><legend><a name="anim">anim</a> - 弹出动画</legend></fieldset></div>
  798. <dd class="site-text">
  799. <p><span>类型</span>:Number,<span>默认</span>:0</p>
  800. <p>我们的出场动画全部采用CSS3。这意味着除了ie6-9,其它所有浏览器都是支持的。目前anim可支持的动画类型有<em>0-6</em> 如果不想显示动画,设置 anim: -1 即可。另外需要注意的是,3.0之前的版本用的是 <em>shift</em> 参数</p>
  801. </dd>
  802. <table class="layui-table">
  803. <thead>
  804. <tr>
  805. <th>值</th>
  806. <th>备注</th>
  807. </tr>
  808. </thead>
  809. <tbody>
  810. <tr>
  811. <td>anim: 0</td>
  812. <td>平滑放大。默认</td>
  813. </tr>
  814. <tr>
  815. <td>anim: 1</td>
  816. <td>从上掉落</td>
  817. </tr>
  818. <tr>
  819. <td>anim: 2</td>
  820. <td>从最底部往上滑入</td>
  821. </tr>
  822. <tr>
  823. <td>anim: 3</td>
  824. <td>从左滑入</td>
  825. </tr>
  826. <tr>
  827. <td>anim: 4</td>
  828. <td>从左翻滚</td>
  829. </tr>
  830. <tr>
  831. <td>anim: 5</td>
  832. <td>渐显</td>
  833. </tr>
  834. <tr>
  835. <td>anim: 6</td>
  836. <td>抖动</td>
  837. </tr>
  838. </tbody>
  839. </table>
  840. <div class="site-title"><fieldset><legend><a name="isOutAnim">isOutAnim</a> - 关闭动画 (layer 3.0.3新增)</legend></fieldset></div>
  841. <dd class="site-text">
  842. <p><span>类型</span>:Boolean,<span>默认</span>:true</p>
  843. <p>默认情况下,关闭层时会有一个过度动画。如果你不想开启,设置 isOutAnim: false 即可</p>
  844. </dd>
  845. <div class="site-title"><fieldset><legend><a name="maxmin">maxmin</a> - 最大最小化。</legend></fieldset></div>
  846. <dd class="site-text">
  847. <p><span>类型</span>:Boolean,<span>默认</span>:false</p>
  848. <p>该参数值对<em>type:1</em>和<em>type:2</em>有效。默认不显示最大小化按钮。需要显示配置<em>maxmin: true</em>即可</p>
  849. </dd>
  850. <div class="site-title"><fieldset><legend><a name="fixed">fixed</a> - 固定</legend></fieldset></div>
  851. <dd class="site-text">
  852. <p><span>类型</span>:Boolean,<span>默认</span>:true</p>
  853. <p>即鼠标滚动时,层是否固定在可视区域。如果不想,设置<em>fixed: false</em>即可</p>
  854. </dd>
  855. <div class="site-title"><fieldset><legend><a name="resize">resize</a> - 是否允许拉伸</legend></fieldset></div>
  856. <dd class="site-text">
  857. <p><span>类型</span>:Boolean,<span>默认</span>:true</p>
  858. <p>默认情况下,你可以在弹层右下角拖动来拉伸尺寸。如果对指定的弹层屏蔽该功能,设置 false即可。该参数对loading、tips层无效</p>
  859. </dd>
  860. <div class="site-title"><fieldset><legend><a name="resizing">resizing</a> - 监听窗口拉伸动作</legend></fieldset></div>
  861. <dd class="site-text">
  862. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  863. <p>当你拖拽弹层右下角对窗体进行尺寸调整时,如果你设定了该回调,则会执行。回调返回一个参数:当前层的DOM对象</p>
  864. <pre class="layui-code">
  865. resizing: function(layero){
  866. console.log(layero);
  867. }
  868. </pre>
  869. </dd>
  870. <div class="site-title"><fieldset><legend><a name="scrollbar">scrollbar</a> - 是否允许浏览器出现滚动条</legend></fieldset></div>
  871. <dd class="site-text">
  872. <p><span>类型</span>:Boolean,<span>默认</span>:true</p>
  873. <p>默认允许浏览器滚动,如果设定<em>scrollbar: false</em>,则屏蔽</p>
  874. </dd>
  875. <div class="site-title"><fieldset><legend><a name="maxWidth">maxWidth</a> - 最大宽度</legend></fieldset></div>
  876. <dd class="site-text">
  877. <p><span>类型</span>:Number,<span>默认</span>:360</p>
  878. <p>请注意:只有当<em>area: 'auto'</em>时,maxWidth的设定才有效。</p>
  879. </dd>
  880. <div class="site-title"><fieldset><legend><a name="maxHeight">maxHeight</a> - 最大高度</legend></fieldset></div>
  881. <dd class="site-text">
  882. <p><span>类型</span>:Number,<span>默认</span>:无</p>
  883. <p>请注意:只有当高度自适应时,maxHeight的设定才有效。</p>
  884. </dd>
  885. <div class="site-title"><fieldset><legend><a name="zIndex">zIndex</a> - 层叠顺序</legend></fieldset></div>
  886. <dd class="site-text">
  887. <p><span>类型</span>:,<span>默认</span>:19891014(贤心生日 0.0)</p>
  888. <p>一般用于解决和其它组件的层叠冲突。</p>
  889. </dd>
  890. <div class="site-title"><fieldset><legend><a name="move">move</a> - 触发拖动的元素</legend></fieldset></div>
  891. <dd class="site-text">
  892. <p><span>类型</span>:String/DOM/Boolean,<span>默认</span>:'.layui-layer-title'</p>
  893. <p>默认是触发标题区域拖拽。如果你想单独定义,指向元素的选择器或者DOM即可。如<em>move: '.mine-move'</em>。你还配置设定<em>move: false</em>来禁止拖拽</p>
  894. </dd>
  895. <div class="site-title"><fieldset><legend><a name="moveOut">moveOut</a> - 是否允许拖拽到窗口外</legend></fieldset></div>
  896. <dd class="site-text">
  897. <p><span>类型</span>:Boolean,<span>默认</span>:false</p>
  898. <p>默认只能在窗口内拖拽,如果你想让拖到窗外,那么设定<em>moveOut: true</em>即可</p>
  899. </dd>
  900. <div class="site-title"><fieldset><legend><a name="moveEnd">moveEnd</a> - 拖动完毕后的回调方法</legend></fieldset></div>
  901. <dd class="site-text">
  902. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  903. <p>默认不会触发moveEnd,如果你需要,设定<em>moveEnd: function(layero){}</em>即可。其中layero为当前层的DOM对象</p>
  904. </dd>
  905. <div class="site-title"><fieldset><legend><a name="tips">tips</a> - tips方向和颜色</legend></fieldset></div>
  906. <dd class="site-text">
  907. <p><span>类型</span>:Number/Array,<span>默认</span>:2</p>
  908. <p>tips层的私有参数。支持<em>上</em><em>右</em><em>下</em><em>左</em>四个方向,通过<em>1-4</em>进行方向设定。如<em>tips: 3</em>则表示在元素的下面出现。有时你还可能会定义一些颜色,可以设定<em>tips: [1, '#c00']</em></p>
  909. </dd>
  910. <div class="site-title"><fieldset><legend><a name="tipsMore">tipsMore</a> - 是否允许多个tips</legend></fieldset></div>
  911. <dd class="site-text">
  912. <p><span>类型</span>:Boolean,<span>默认</span>:false</p>
  913. <p>允许多个意味着不会销毁之前的tips层。通过<em>tipsMore: true</em>开启</p>
  914. </dd>
  915. <div class="site-title"><fieldset><legend><a name="success">success</a> - 层弹出后的成功回调方法</legend></fieldset></div>
  916. <dd class="site-text">
  917. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  918. <p>当你需要在层创建完毕时即执行一些语句,可以通过该回调。success会携带两个参数,分别是<em>当前层DOM</em><em>当前层索引</em>。如:</p>
  919. <pre class="layui-code">
  920. layer.open({
  921. content: '测试回调',
  922. success: function(layero, index){
  923. console.log(layero, index);
  924. }
  925. });
  926. </pre>
  927. </dd>
  928. <div class="site-title"><fieldset><legend><a name="yes">yes</a> - 确定按钮回调方法</legend></fieldset></div>
  929. <dd class="site-text">
  930. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  931. <p>该回调携带两个参数,分别为当前层索引、当前层DOM对象。如:</p>
  932. <pre class="layui-code">
  933. layer.open({
  934. content: '测试回调',
  935. yes: function(index, layero){
  936. //do something
  937. layer.close(index); //如果设定了yes回调,需进行手工关闭
  938. }
  939. });
  940. </pre>
  941. </dd>
  942. <div class="site-title"><fieldset><legend><a name="cancel">cancel</a> - 右上角关闭按钮触发的回调</legend></fieldset></div>
  943. <dd class="site-text">
  944. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  945. <p>该回调携带两个参数,分别为:当前层索引参数(index)、当前层的DOM对象(layero),默认会自动触发关闭。如果不想关闭,<em>return false</em>即可,如;</p>
  946. <pre class="layui-code">
  947. cancel: function(index, layero){
  948. if(confirm('确定要关闭么')){ //只有当点击confirm框的确定时,该层才会关闭
  949. layer.close(index)
  950. }
  951. return false;
  952. }
  953. </pre>
  954. </dd>
  955. <div class="site-title"><fieldset><legend><a name="end">end</a> - 层销毁后触发的回调</legend></fieldset></div>
  956. <dd class="site-text">
  957. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  958. <p>无论是确认还是取消,只要层被销毁了,end都会执行,不携带任何参数。</p>
  959. </dd>
  960. <div class="site-title"><fieldset><legend><a name="full">full/min/restore</a> -分别代表最大化、最小化、还原 后触发的回调</legend></fieldset></div>
  961. <dd class="site-text">
  962. <p><span>类型</span>:Function,<span>默认</span>:null</p>
  963. <p>携带两个参数,即当前层 DOM、当前层索引</p>
  964. <pre class="layui-code">
  965. min: function(layero, index){ //<span class="layui-font-red">index 参数为 layui 2.6.6 或独立版 layer 3.5.0 开始新增</span>
  966. //当层最小化时触发
  967. //自定义操作,并阻止默认最小化
  968. //layer.min(index); //单独执行最小化
  969. //return false; //阻止默认最小化
  970. }
  971. </pre>
  972. </dd>
  973. <div class="site-title">
  974. <fieldset><legend><a name="minStack">minStack</a> - 是否默认堆叠在左下角</legend></fieldset>
  975. </div>
  976. <dd class="site-text">
  977. <p><span>类型</span>:Boolean,<span>默认</span>:true</p>
  978. <p class="layui-font-red">layui 2.6.6 或独立版 layer 3.5.0 开始新增</p>
  979. </dd>
  980. </dl>
  981. <dl>
  982. <div class="site-title"><fieldset><legend><a name="layer.config">layer.config(options)</a> - 初始化全局配置</legend></fieldset></div>
  983. <dd class="site-text">
  984. <p>这是一个可以重要也可以不重要的方法,重要的是,它的权利真的很大,尤其是在模块化加载layer时,你会发现你必须要用到它。它不仅可以配置一些诸如路径、加载的模块,甚至还可以决定整个弹层的默认参数。而说它不重要,是因为多数情况下,你会发现,你似乎不是那么十分需要它。但你真的需要认识一下这位伙计。</p>
  985. <p>如果您是采用<em>seajs</em>或者<em>requirejs</em>加载layer,你需要执行该方法来完成初始化的配置。比如:</p>
  986. <pre class="layui-code">
  987. layer.config({
  988. path: '/res/layer/' //layer.js所在的目录,可以是绝对目录,也可以是相对目录
  989. });
  990. //这样的话,layer就会去加载一些它所需要的配件,比如 css 等。
  991. //当然,你即便不用seajs或者requirejs,也可以通过上述方式设定路径
  992. </pre>
  993. <p>如果你是采用合并的方式引入 layer,那么您需要在 script 标签上加一个自定义属性 <code>merge="true"</code>。如:</p>
  994. <pre class="layui-code">
  995. &lt;script src="?a.js&layer.js" merge="true"&gt;
  996. 如此,layer 则不会去自动获取路径,但你需要通过以下方式来完成初始化的配置
  997. layer.config({
  998. path: '/res/layer/' //layer.js 所在的目录,可以是绝对目录,也可以是相对目录
  999. });
  1000. </pre>
  1001. <p>除上述之外,如果您采用的是独立的 layer,那么你还可以在动态加载 <code>layer</code> 之前预先定义一个我们约定好的全局对象:</p>
  1002. <pre class="layui-code">
  1003. &lt;script&gt;
  1004. var LAYUI_GLOBAL = {
  1005. layer_dir: '/res/layer/' //layer 所在目录(layer 3.5 开始新增)
  1006. };
  1007. &lt;/script&gt;
  1008. </pre>
  1009. <blockquote class="layui-elem-quote layui-text">
  1010. 提示 1:上述只针对独立版 layer,其 LAYUI_GLOBAL 设定的 layer_dir 优先级高于 layer.config 设定的 path;
  1011. <br>提示 2:如果是 layui 加载的 layer,可以无视上述所有的目录设定。前置工作都会在 layui 内部完成。
  1012. </blockquote>
  1013. <p>另外,layer.config 还可以配置层 <em>默认的基础参数</em>,如:</p>
  1014. <pre class="layui-code">
  1015. layer.config({
  1016. anim: 1, //默认动画风格
  1017. skin: 'layui-layer-molv' //默认皮肤
  1018. //…
  1019. });
  1020. //除此之外,extend 还允许你加载拓展的 css 皮肤,如:
  1021. layer.config({
  1022. //如果是独立版的layer,则将 myskin 存放在 ./skin 目录下
  1023. //如果是layui中使用layer,则将 myskin 存放在 ./css/modules/layer 目录下
  1024. extend: 'myskin/style.css'
  1025. });
  1026. //具体的皮肤定制,可以参见:<a href="#skin">skin参数说明</a>
  1027. </pre>
  1028. </dd>
  1029. <div class="site-title"><fieldset><legend><a name="layer.ready">layer.ready(callback)</a> - 初始化就绪</legend></fieldset></div>
  1030. <dd class="site-text">
  1031. <p>由于我们的layer内置了轻量级加载器,所以你根本不需要单独引入css等文件。但是加载总是需要过程的。当你在页面一打开就要执行弹层时,你最好是将弹层放入ready方法中,如:</p>
  1032. <pre class="layui-code">
  1033. //页面一打开就执行弹层
  1034. layer.ready(function(){
  1035. layer.msg('很高兴一开场就见到你');
  1036. });
  1037. </pre>
  1038. <p style="padding:10px 0; color:#999">我是华丽的酱油:介绍完上面两位引导者,接下来我们真正的主角闪亮登场了。此处应有掌声 ^,^</p>
  1039. </dd>
  1040. <div class="site-title"><fieldset><legend><a name="layer.open">layer.open(options)</a> - 原始核心方法</legend></fieldset></div>
  1041. <dd class="site-text">
  1042. <p>基本上是露脸率最高的方法,不管是使用哪种方式创建层,都是走<em>layer.open()</em>,创建任何类型的弹层都会返回一个当前层索引,上述的<em>options即是基础参数</em>,另外,该文档<em>统一采用options作为基础参数的标识</em>例子:</p>
  1043. <pre class="layui-code">
  1044. var index = layer.open({
  1045. content: 'test'
  1046. });
  1047. //拿到的index是一个重要的凭据,它是诸如layer.close(index)等方法的必传参数。
  1048. </pre>
  1049. <p style="color:#999">噢,请等等,上面这位主角的介绍篇幅怎么看怎么都觉得跟它的地位不符,作者在文档中只给了它如此可怜的一块地??这是因为,它真的已经大众得不能再大众了,你真正需要了解的,是它的内部器官,即上面一大篇幅介绍的各种基础参数。 ←_←</p>
  1050. </dd>
  1051. <div class="site-title"><fieldset><legend><a name="layer.alert">layer.alert(content, options, yes)</a> - 普通信息框</legend></fieldset></div>
  1052. <dd class="site-text">
  1053. <p>它的弹出似乎显得有些高调,一般用于对用户造成比较强烈的关注,类似系统alert,但却比alert更灵便。它的参数是自动向左补齐的。通过第二个参数,可以设定各种你所需要的基础参数,但如果你不需要的话,直接写回调即可。如</p>
  1054. <pre class="layui-code">
  1055. //eg1
  1056. layer.alert('只想简单的提示');
  1057. //eg2
  1058. layer.alert('加了个图标', {icon: 1}); //这时如果你也还想执行yes回调,可以放在第三个参数中。
  1059. //eg3
  1060. layer.alert('有了回调', function(index){
  1061. //do something
  1062. layer.close(index);
  1063. });
  1064. </pre>
  1065. </dd>
  1066. <div class="site-title"><fieldset><legend><a name="layer.confirm">layer.confirm(content, options, yes, cancel)</a> - 询问框</legend></fieldset></div>
  1067. <dd class="site-text">
  1068. <p>类似系统confirm,但却远胜confirm,另外它<em>不是和系统的confirm一样阻塞</em>你需要把交互的语句放在回调体中。同样的,它的参数也是自动补齐的。</p>
  1069. <pre class="layui-code">
  1070. //eg1
  1071. layer.confirm('is not?', {icon: 3, title:'提示'}, function(index){
  1072. //do something
  1073. layer.close(index);
  1074. });
  1075. //eg2
  1076. layer.confirm('is not?', function(index){
  1077. //do something
  1078. layer.close(index);
  1079. });
  1080. </pre>
  1081. </dd>
  1082. <div class="site-title"><fieldset><legend><a name="layer.msg">layer.msg(content, options, end)</a> - 提示框</legend></fieldset></div>
  1083. <dd class="site-text">
  1084. <p>我们在源码中用了相对较大的篇幅来定制了这个msg,目的是想将其打造成露脸率最高的提示框。而事实上我的确也在大量地使用它。因为它简单,而且足够得自觉,它不仅占据很少的面积,而且默认还会3秒后<em>自动消失</em>所有这一切都决定了我对msg的爱。因此<em>我赋予了它许多可能</em>在外形方面,它坚持简陋的变化,在作用方面,它坚持零用户操作。而且它的参数也是自动补齐的。</p>
  1085. <pre class="layui-code">
  1086. //eg1
  1087. layer.msg('只想弱弱提示');
  1088. //eg2
  1089. layer.msg('有表情地提示', {icon: 6});
  1090. //eg3
  1091. layer.msg('关闭后想做些什么', function(){
  1092. //do something
  1093. });
  1094. //eg
  1095. layer.msg('同上', {
  1096. icon: 1,
  1097. time: 2000 //2秒关闭(如果不配置,默认是3秒)
  1098. }, function(){
  1099. //do something
  1100. });
  1101. </pre>
  1102. </dd>
  1103. <div class="site-title"><fieldset><legend><a name="layer.load">layer.load(icon, options)</a> - 加载层</legend></fieldset></div>
  1104. <dd class="site-text">
  1105. <p>type:3的深度定制。load并不需要你传太多的参数,但如果你不喜欢默认的加载风格,你还有选择空间。icon支持传入<em>0-2</em>如果是0,无需传。另外特别注意一点:<em>load默认是不会自动关闭的</em>,因为你一般会在ajax回调体中关闭它。</p>
  1106. <pre class="layui-code">
  1107. //eg1
  1108. var index = layer.load();
  1109. //eg2
  1110. var index = layer.load(1); //换了种风格
  1111. //eg3
  1112. var index = layer.load(2, {time: 10*1000}); //又换了种风格,并且设定最长等待10秒
  1113. //关闭
  1114. layer.close(index);
  1115. </pre>
  1116. </dd>
  1117. <div class="site-title"><fieldset><legend><a name="layer.tips">layer.tips(content, follow, options)</a> - tips层</legend></fieldset></div>
  1118. <dd class="site-text">
  1119. <p>type:4的深度定制。也是我本人比较喜欢的一个层类型,因为它拥有和msg一样的低调和自觉,而且会<em>智能定位</em>,即灵活地判断它应该出现在哪边。默认是在元素右边弹出</p>
  1120. <pre class="layui-code">
  1121. //eg1
  1122. layer.tips('只想提示地精准些', '#id');
  1123. //eg 2
  1124. $('#id').on('click', function(){
  1125. var that = this;
  1126. layer.tips('只想提示地精准些', that); //在元素的事件回调体中,follow直接赋予this即可
  1127. });
  1128. //eg 3
  1129. layer.tips('在上面', '#id', {
  1130. tips: 1
  1131. });
  1132. </pre>
  1133. </dd>
  1134. <p style="padding-bottom:10px; color:#999">上面主要是一些弹层的调用方式,而下面介绍的是一些辅助性的方法</p>
  1135. <div class="site-title"><fieldset><legend><a name="layer.close">layer.close(index)</a> - 关闭指定层</legend></fieldset></div>
  1136. <dd class="site-text">
  1137. <p>关于它似乎没有太多介绍的必要,唯一让你疑惑的,可能就是这个<em>index</em>了吧。事实上它非常容易得到。</p>
  1138. <pre class="layui-code">
  1139. //当你想关闭当前页的某个层时
  1140. var index = layer.open();
  1141. var index = layer.alert();
  1142. var index = layer.load();
  1143. var index = layer.tips();
  1144. //正如你看到的,每一种弹层调用方式,都会返回一个index
  1145. layer.close(index); //此时你只需要把获得的index,轻轻地赋予layer.close即可
  1146. //如果你想关闭最新弹出的层,直接获取layer.index即可
  1147. layer.close(layer.index); //它获取的始终是最新弹出的某个层,值是由layer内部动态递增计算的
  1148. //当你在iframe页面关闭自身时
  1149. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  1150. parent.layer.close(index); //再执行关闭
  1151. //关闭后的回调(layui 2.6.5、layer 3.4.0 新增)
  1152. layer.close(index, function(){
  1153. //do something
  1154. });
  1155. </pre>
  1156. </dd>
  1157. <div class="site-title"><fieldset><legend><a name="layer.closeAll">layer.closeAll(type)</a> - 关闭所有层</legend></fieldset></div>
  1158. <dd class="site-text">
  1159. <p>如果你很懒,你<em>不想去获取index</em>你只想关闭。那么closeAll真的可以帮上你。如果你不指向层类型的话,它会销毁掉当前页所有的layer层。当然,如果你只想关闭某个类型的层,那么你可以</p>
  1160. <pre class="layui-code">
  1161. layer.closeAll(); //疯狂模式,关闭所有层
  1162. layer.closeAll('dialog'); //关闭信息框
  1163. layer.closeAll('page'); //关闭所有页面层
  1164. layer.closeAll('iframe'); //关闭所有的iframe层
  1165. layer.closeAll('loading'); //关闭加载层
  1166. layer.closeAll('tips'); //关闭所有的tips层
  1167. //关闭后的回调(layui 2.6.5、layer 3.4.0 新增)
  1168. layer.closeAll('loading', function(){ //关闭 loading 并执行回调
  1169. //do something
  1170. });
  1171. layer.closeAll(function(){ //关闭所有层并执行回调
  1172. //do something
  1173. });
  1174. </pre>
  1175. </dd>
  1176. <div class="site-title"><fieldset><legend><a name="layer.style">layer.style(index, cssStyle)</a> - 重新定义层的样式</legend></fieldset></div>
  1177. <dd class="site-text">
  1178. <p>该方法对loading层和tips层无效。参数index为层的索引,cssStyle允许你传入任意的css属性</p>
  1179. <pre class="layui-code">
  1180. //重新给指定层设定width、top等
  1181. layer.style(index, {
  1182. width: '1000px',
  1183. top: '10px'
  1184. });
  1185. </pre>
  1186. </dd>
  1187. <div class="site-title"><fieldset><legend><a name="layer.title">layer.title(title, index)</a> - 改变层的标题</legend></fieldset></div>
  1188. <dd class="site-text">
  1189. <p>使用方式:<em>layer.title('标题变了', index)</em></p>
  1190. </dd>
  1191. <div class="site-title"><fieldset><legend><a name="layer.getChildFrame">layer.getChildFrame(selector, index)</a> - 获取iframe页的DOM</legend></fieldset></div>
  1192. <dd class="site-text">
  1193. <p>当你试图在当前页获取iframe页的DOM元素时,你可以用此方法。<em>selector即iframe页的选择器</em></p>
  1194. <pre class="layui-code">
  1195. layer.open({
  1196. type: 2,
  1197. content: 'test/iframe.html',
  1198. success: function(layero, index){
  1199. var body = layer.getChildFrame('body', index);
  1200. var iframeWin = window[layero.find('iframe')[0]['name']]; //得到iframe页的窗口对象,执行iframe页的方法:iframeWin.method();
  1201. console.log(body.html()) //得到iframe页的body内容
  1202. body.find('input').val('Hi,我是从父页来的')
  1203. }
  1204. });
  1205. </pre>
  1206. </dd>
  1207. <div class="site-title"><fieldset><legend><a name="layer.getFrameIndex">layer.getFrameIndex(windowName)</a> - 获取特定iframe层的索引</legend></fieldset></div>
  1208. <dd class="site-text">
  1209. <p>此方法一般用于在iframe页关闭自身时用到。</p>
  1210. <pre class="layui-code">
  1211. //假设这是iframe页
  1212. var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe层的索引
  1213. parent.layer.close(index); //再执行关闭
  1214. </pre>
  1215. </dd>
  1216. <div class="site-title"><fieldset><legend><a name="layer.iframeAuto">layer.iframeAuto(index)</a> - 指定iframe层自适应</legend></fieldset></div>
  1217. <dd class="site-text">
  1218. <p>调用该方法时,iframe层的高度会重新进行适应</p>
  1219. </dd>
  1220. <div class="site-title"><fieldset><legend><a name="layer.iframeSrc">layer.iframeSrc(index, url)</a> - //重置特定iframe url</legend></fieldset></div>
  1221. <dd class="site-text">
  1222. <p>似乎不怎么常用的样子。使用方式:<em>layer.iframeSrc(index, 'http://sentsin.com')</em></p>
  1223. </dd>
  1224. <div class="site-title"><fieldset><legend><a name="layer.setTop">layer.setTop(layero)</a> -置顶当前窗口 </legend></fieldset></div>
  1225. <dd class="site-text">
  1226. <p>非常强大的一个方法,虽然一般很少用。但是当你的页面有很多很多layer窗口,你需要像Window窗体那样,点击某个窗口,该窗体就置顶在上面,那么setTop可以来轻松实现。它采用巧妙的逻辑,以使这种置顶的性能达到最优</p>
  1227. <pre class="layui-code">
  1228. //通过这种方式弹出的层,每当它被选择,就会置顶。
  1229. layer.open({
  1230. type: 2,
  1231. shade: false,
  1232. area: '500px',
  1233. maxmin: true,
  1234. content: 'http://www.layui.com',
  1235. zIndex: layer.zIndex, //重点1
  1236. success: function(layero){
  1237. layer.setTop(layero); //重点2
  1238. }
  1239. });
  1240. </pre>
  1241. </dd>
  1242. <div class="site-title"><fieldset><legend><a name="layer.full">layer.full()、layer.min()、layer.restore()</a> - 手工执行最大小化</legend></fieldset></div>
  1243. <dd class="site-text">
  1244. <p>一般用于在自定义元素上触发最大化、最小化和全屏。</p>
  1245. <pre class="layui-code">
  1246. layer.full(index); //执行最大化
  1247. layer.min(index); //执行最小化
  1248. layer.restore(index); //执行还原
  1249. </pre>
  1250. </dd>
  1251. </dl>
  1252. <dl>
  1253. <div class="site-title"><fieldset><legend><a name="layer.prompt">layer.prompt(options, yes)</a> - 输入层</legend></fieldset></div>
  1254. <dd class="site-text">
  1255. <p>prompt的参数也是向前补齐的。options不仅可支持传入基础参数,还可以传入prompt专用的属性。当然,也可以不传。yes携带<em>value 表单值</em><em>index 索引</em><em>elem 表单元素</em></p>
  1256. <pre class="layui-code">
  1257. //prompt层新定制的成员如下
  1258. {
  1259. formType: 1, //输入框类型,支持<em>0(文本)默认</em><em>1(密码)</em><em>2(多行文本)</em>
  1260. value: '', //初始时的值,默认空字符
  1261. maxlength: 140, //可输入文本的最大长度,默认500
  1262. }
  1263. //例子1
  1264. layer.prompt(function(value, index, elem){
  1265. alert(value); //得到value
  1266. layer.close(index);
  1267. });
  1268. //例子2
  1269. layer.prompt({
  1270. formType: 2,
  1271. value: '初始值',
  1272. title: '请输入值',
  1273. area: ['800px', '350px'] //自定义文本域宽高
  1274. }, function(value, index, elem){
  1275. alert(value); //得到value
  1276. layer.close(index);
  1277. });
  1278. </pre>
  1279. </dd>
  1280. <div class="site-title"><fieldset><legend><a name="layer.tab">layer.tab(options)</a> - tab层</legend></fieldset></div>
  1281. <dd class="site-text">
  1282. <p>tab层只单独定制了一个成员,即<em>tab: []</em>,这个好像没有什么可介绍的,简单粗暴看例子</p>
  1283. <pre class="layui-code">
  1284. layer.tab({
  1285. area: ['600px', '300px'],
  1286. tab: [{
  1287. title: 'TAB1',
  1288. content: '内容1'
  1289. }, {
  1290. title: 'TAB2',
  1291. content: '内容2'
  1292. }, {
  1293. title: 'TAB3',
  1294. content: '内容3'
  1295. }]
  1296. });
  1297. </pre>
  1298. </dd>
  1299. <div class="site-title"><fieldset><legend><a name="layer.photos">layer.photos(options)</a> - 相册层</legend></fieldset></div>
  1300. <dd class="site-text">
  1301. <p>相册层,也可以称之为图片查看器。它的出场动画从layer内置的动画类型中随机展现。photos支持传入json和直接读取页面图片两种方式。如果是json传入,如下:</p>
  1302. <pre class="layui-code">
  1303. $.getJSON('/jquery/layer/test/photos.json', function(json){
  1304. layer.photos({
  1305. photos: json
  1306. ,anim: 5 //0-6的选择,指定弹出图片动画类型,默认随机(请注意,3.0之前的版本用shift参数)
  1307. });
  1308. });
  1309. //而返回的json需严格按照如下格式:
  1310. <pre class="layui-code">
  1311. {
  1312. "title": "", //相册标题
  1313. "id": 123, //相册id
  1314. "start": 0, //初始显示的图片序号,默认0
  1315. "data": [ //相册包含的图片,数组格式
  1316. {
  1317. "alt": "图片名",
  1318. "pid": 666, //图片id
  1319. "src": "", //原图地址
  1320. "thumb": "" //缩略图地址
  1321. }
  1322. ]
  1323. }
  1324. </pre>
  1325. </pre>
  1326. <p>如果是直接从页面中获取图片,那么需要指向图片的父容器,并且你的img可以设定一些规定的属性(但不是必须的)。</p>
  1327. <pre class="layui-code">
  1328. //HTML示例
  1329. &lt;div id="layer-photos-demo" class="layer-photos-demo"&gt;
  1330. &lt;img layer-pid="图片id,可以不写" layer-src="大图地址" src="缩略图" alt="图片名"&gt;
  1331. &lt;img layer-pid="图片id,可以不写" layer-src="大图地址" src="缩略图" alt="图片名"&gt;
  1332. &lt;/div&gt;
  1333. &lt;script&gt;
  1334. //调用示例
  1335. layer.photos({
  1336. photos: '#layer-photos-demo'
  1337. ,anim: 5 //0-6的选择,指定弹出图片动画类型,默认随机(请注意,3.0之前的版本用shift参数)
  1338. });
  1339. &lt;/script&gt;
  1340. </pre>
  1341. <p>看看一个实例呗:</p>
  1342. <div id="layer-photos-demo" class="layer-photos-demo">
  1343. <img layer-src="/public/upload/2017_3/168_1488985841996_23077.png" tppabs="http://cdn.layui.com/upload/2017_3/168_1488985841996_23077.png" layer-pid="" src="/public/upload/2017_3/168_1488985841996_23077.png" tppabs="http://cdn.layui.com/upload/2017_3/168_1488985841996_23077.png" alt="layer专注弹层100年">
  1344. <img layer-src="/public/static/images/fly/fly.jpg" tppabs="http://res.layui.com/static/images/fly/fly.jpg" layer-pid="" src="/public/static/images/fly/fly.jpg" tppabs="http://res.layui.com/static/images/fly/fly.jpg" alt="说好的,一起Fly">
  1345. <img layer-src="/public/static/images/sentsin/night.gif" tppabs="http://res.layui.com/static/images/sentsin/night.gif" layer-pid="" src="/public/static/images/sentsin/night.gif" tppabs="http://res.layui.com/static/images/sentsin/night.gif" alt="星空如此深邃">
  1346. </div>
  1347. <p>第二种方式的图片查看器显然更加简单,因为无需像第一种那样返回规定的json,但是他们还是有各自的应用场景的,你可以按照你的需求进行选择。另外,photos还有个tab回调,切换图片时触发。</p>
  1348. <pre class="layui-code">
  1349. layer.photos({
  1350. photos: json/选择器,
  1351. tab: function(pic, layero){
  1352. console.log(pic) //当前图片的一些信息
  1353. }
  1354. });
  1355. </pre>
  1356. </dd>
  1357. </dl>
  1358. <fieldset class="layui-elem-field layui-field-title site-title">
  1359. <legend>结语</legend>
  1360. </fieldset>
  1361. <div class="site-text">
  1362. <p>合理地设定基础参数,合理地选择内置方法,合理的心态,合理地阅读,只要一切都在合理的前提下,你才会感知到layer许许多多令人愉悦的地方,<em>她真的是否如你所愿,取决于你对她了解的深远</em>。愿layer能给你的web开发带来一段美妙的旅程。别忘了在线调试。
  1363. </p>
  1364. </div>
  1365. <div class="layui-elem-quote">
  1366. <p>layui - 在每一个细节中,用心与你沟通</p>
  1367. </div>
  1368. </div>
  1369. </div>
  1370. <style>
  1371. .runtest{position: relative; display:none;}
  1372. .runtest textarea{display:block; width: 300px; height: 160px; border: 10px solid #F8F8F8; border-top-width: 0; padding: 10px; line-height:20px; overflow:auto; background-color: #3F3F3F; color: #eee; font-size:12px; font-family:Courier New;}
  1373. .runtest a{position: absolute; right: 20px; bottom: 20px;}
  1374. .layer-photos-demo{margin:10px 0;}
  1375. .layer-photos-demo img{width: 160px; height: 100px;}
  1376. </style>
  1377. <div class="runtest">
  1378. <textarea class="site-demo-text" id="testmain">
  1379. layer.open({
  1380. title: '在线调试'
  1381. ,content: '配置各种参数,试试效果'
  1382. });
  1383. </textarea>
  1384. <a href="javascript:;" class="layui-btn layui-btn-normal" onclick="try{new Function(testmain.value)();}catch(e){alert('语句异常:'+e.message)}" class="btns">立即运行</a>
  1385. </div>
  1386. <div class="layui-footer footer footer-doc">
  1387. <p>
  1388. Copyright &copy; 2021 <a href="../../index.html" tppabs="http://www.layui.com/">「本站仅为 layui 文档保留的镜像站点,与官方无关」</a> MIT Licensed</p>
  1389. <p>
  1390. <a href="../../about/disclaimer.html" tppabs="http://www.layui.com/about/disclaimer.html" target="_blank">免责声明</a>
  1391. <a href="../../about/relatedlinks.html" tppabs="http://www.layui.com/about/relatedlinks.html" target="_blank">友链</a>
  1392. <a href="javascript:;" site-event="weixinmp">公众号</a>
  1393. </p>
  1394. </div>
  1395. <script>
  1396. window.global = {
  1397. pageType: 'doc'
  1398. ,preview: function(){
  1399. var preview = document.getElementById('LAY_preview');
  1400. return preview ? preview.innerHTML : '';
  1401. }()
  1402. };
  1403. </script>
  1404. <div class="site-tree-mobile layui-hide">
  1405. <i class="layui-icon layui-icon-spread-left"></i>
  1406. </div>
  1407. <div class="site-mobile-shade"></div>
  1408. <script src="/public/layui/dist/layui.js" tppabs="http://res.layui.com/layui/dist/layui.js?t=1632428048355" charset="utf-8"></script>
  1409. <script>
  1410. layui.config({
  1411. base: '/public/static/lay/modules/layui/'
  1412. ,version: '1632428048355'
  1413. }).use('global');
  1414. </script>
  1415. <script>
  1416. layui.use('layer', function(){
  1417. var $ = layui.jquery
  1418. ,layer = layui.layer;
  1419. if($(window).width() <= 750) return;
  1420. var debug = $('#L_layerDebug'), popDebug = function(){
  1421. layer.open({
  1422. type: 1
  1423. ,title: '在线调试'
  1424. ,id: 'Lay_layer_debug'
  1425. ,content: $('.runtest')
  1426. ,shade: false
  1427. ,offset: 'rb'
  1428. ,resize: false
  1429. ,success: function(layero, index){
  1430. layer.style(index, {
  1431. marginLeft: -220
  1432. });
  1433. debug.hide();
  1434. }
  1435. ,end: function(){
  1436. debug.show();
  1437. }
  1438. });
  1439. testmain.focus();
  1440. };
  1441. debug.on('click', popDebug);
  1442. layer.ready(function(){
  1443. layer.photos({
  1444. photos: '#layer-photos-demo'
  1445. });
  1446. popDebug();
  1447. });
  1448. });
  1449. </script>
  1450. </body>
  1451. </html>