layer.html 70 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589
  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. <a target="_blank" href="http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=00000000000000" rel="nofollow">
  1394. <img src="/public/upload/2021_8/168_1628847893037_87773.png" tppabs="http://cdn.layui.com/upload/2021_8/168_1628847893037_87773.png">
  1395. 公网安备 00000000000000号
  1396. </a>
  1397. <a href="https://beian.miit.gov.cn/" target="_blank" rel="nofollow">ICP备00000000号</a>
  1398. </p>
  1399. <div class="site-union">
  1400. <p class="site-union-desc">
  1401. <span>
  1402. 感谢以下平台提供云加速支持
  1403. </span>
  1404. </p>
  1405. </div>
  1406. </div>
  1407. <script>
  1408. window.global = {
  1409. pageType: 'doc'
  1410. ,preview: function(){
  1411. var preview = document.getElementById('LAY_preview');
  1412. return preview ? preview.innerHTML : '';
  1413. }()
  1414. };
  1415. </script>
  1416. <div class="site-tree-mobile layui-hide">
  1417. <i class="layui-icon layui-icon-spread-left"></i>
  1418. </div>
  1419. <div class="site-mobile-shade"></div>
  1420. <script src="/public/layui/dist/layui.js" tppabs="http://res.layui.com/layui/dist/layui.js?t=1632428048355" charset="utf-8"></script>
  1421. <script>
  1422. layui.config({
  1423. base: '/public/static/lay/modules/layui/'
  1424. ,version: '1632428048355'
  1425. }).use('global');
  1426. </script>
  1427. <script>
  1428. layui.use('layer', function(){
  1429. var $ = layui.jquery
  1430. ,layer = layui.layer;
  1431. if($(window).width() <= 750) return;
  1432. var debug = $('#L_layerDebug'), popDebug = function(){
  1433. layer.open({
  1434. type: 1
  1435. ,title: '在线调试'
  1436. ,id: 'Lay_layer_debug'
  1437. ,content: $('.runtest')
  1438. ,shade: false
  1439. ,offset: 'rb'
  1440. ,resize: false
  1441. ,success: function(layero, index){
  1442. layer.style(index, {
  1443. marginLeft: -220
  1444. });
  1445. debug.hide();
  1446. }
  1447. ,end: function(){
  1448. debug.show();
  1449. }
  1450. });
  1451. testmain.focus();
  1452. };
  1453. debug.on('click', popDebug);
  1454. layer.ready(function(){
  1455. layer.photos({
  1456. photos: '#layer-photos-demo'
  1457. });
  1458. popDebug();
  1459. });
  1460. });
  1461. </script>
  1462. </body>
  1463. </html>