| 1 |
- System.register(["./vendor-legacy.44d419bd.js"],(function(s){"use strict";var a,n,t;return{setters:[function(s){a=s.e,n=s.o,t=s.G}],execute:function(){const l={class:"markdown-body"},p=[t('<h1>Menu 菜单组件</h1><h3>介绍</h3><p>下拉选择菜单组件</p><h3>安装</h3><pre><code class="language-javascript"><span class="hljs-keyword">import</span> { createApp } <span class="hljs-keyword">from</span> <span class="hljs-string">'vue'</span>;\n<span class="hljs-comment">// vue</span>\n<span class="hljs-keyword">import</span> { Menu } <span class="hljs-keyword">from</span> <span class="hljs-string">'@nutui/nutui'</span>;\n<span class="hljs-comment">// taro</span>\n<span class="hljs-keyword">import</span> { Menu,MenuItem } <span class="hljs-keyword">from</span> <span class="hljs-string">'@nutui/nutui-taro'</span>;\n<span class="hljs-keyword">const</span> app = createApp();\napp.use(Menu);\napp.use(MenuItem);\n\n</code></pre><h2>代码演示</h2><h3>基础用法1</h3><p><code>Menu</code> 属性支持传入列表数据menuList和title名称设置。</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"最新商品"</span> ></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">:title</span>=<span class="hljs-string">"title"</span> ></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n<span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><pre><code class="language-js"> <span class="hljs-function"><span class="hljs-title">setup</span>(<span class="hljs-params"></span>)</span> {\n <span class="hljs-keyword">const</span> resData = reactive({\n <span class="hljs-attr">title</span>: <span class="hljs-string">'热门推荐'</span>,\n <span class="hljs-attr">menuList</span>: [\n {<span class="hljs-attr">value</span>: <span class="hljs-string">'手机'</span>},\n {<span class="hljs-attr">value</span>: <span class="hljs-string">'电脑'</span>},\n {<span class="hljs-attr">value</span>: <span class="hljs-string">'家用电器'</span>},\n {<span class="hljs-attr">value</span>: <span class="hljs-string">'日用百货'</span>}\n ]\n });\n }\n\n</code></pre><h3>菜单多列展示</h3><p><code>Menu</code> 的 <code> multiStyle</code> 属性配置1列、2列、3列展示菜单列表,默认单列展示。 <code>maxHeight</code> 属性可控制菜单列表的最大高度。</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"单列展示"</span> <span class="hljs-attr">multi-style</span>=<span class="hljs-string">"1"</span> <span class="hljs-attr">maxHeight</span>=<span class="hljs-string">"200"</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"双列展示"</span> <span class="hljs-attr">multi-style</span>=<span class="hljs-string">"2"</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"三列展示"</span> <span class="hljs-attr">multi-style</span>=<span class="hljs-string">"3"</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n<span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><h3>禁用操作</h3><p><code>Menu</code> 的 <code>disabled</code> 属性可对菜单列表进行禁用操作。 <code>autoClose</code> 属性控制下拉菜单列表是否选择后自动收起,默认自动收起。</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"最新商品"</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"title"</span> <span class="hljs-attr">:auto-close</span>=<span class="hljs-string">"false"</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"筛选"</span> <span class="hljs-attr">disabled</span> ></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n<span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><h3>禁止蒙层展示</h3><p>属性<code>hasMask</code>控制是否有蒙层,默认为 <code>true</code>展示蒙层</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span> <span class="hljs-attr">:hasMask</span>=<span class="hljs-string">"false"</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"最新商品"</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList"</span> <span class="hljs-attr">:title</span>=<span class="hljs-string">"title"</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n<span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><h3>点击事件</h3><p><code>Menu</code> 的 <code>@menu-click</code> 事件返回点击的菜单标题,<code>@change</code>事件返回菜单列表选中的数据。</p><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span>\n <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span>\n <span class="hljs-attr">title</span>=<span class="hljs-string">"选择菜单列表项"</span>\n <span class="hljs-attr">multi-style</span>=<span class="hljs-string">"2"</span>\n @<span class="hljs-attr">menu-click</span>=<span class="hljs-string">"alertText($event, 'title')"</span>\n @<span class="hljs-attr">change</span>=<span class="hljs-string">"getChecked"</span>\n ></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span>\n <span class="hljs-attr">:menu-list</span>=<span class="hljs-string">"menuList2"</span>\n <span class="hljs-attr">title</span>=<span class="hljs-string">"选中标题触发"</span>\n <span class="hljs-attr">disabled</span>\n @<span class="hljs-attr">menu-click</span>=<span class="hljs-string">"alertText"</span>\n ></span><span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><pre><code class="language-js"><span class="hljs-keyword">const</span> getChecked = <span class="hljs-function">(<span class="hljs-params">info: any, name: string</span>) =></span> {\n alert(<span class="hljs-string">'选择菜单选项:'</span> + name);\n <span class="hljs-built_in">console</span>.log(<span class="hljs-number">11</span>, info, name);\n};\n<span class="hljs-keyword">const</span> alertText = <span class="hljs-function">(<span class="hljs-params">info, type</span>) =></span> {\n <span class="hljs-built_in">console</span>.log(info, type);\n <span class="hljs-keyword">if</span> (type == <span class="hljs-string">'title'</span>) {\n alert(<span class="hljs-string">'菜单标题点击:'</span> + info);\n } <span class="hljs-keyword">else</span> {\n alert(<span class="hljs-string">'禁用操作'</span>);\n }\n};\n</code></pre><h3>自定义内容</h3><pre><code class="language-html"><span class="hljs-tag"><<span class="hljs-name">nut-menu</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-menu-item</span> <span class="hljs-attr">title</span>=<span class="hljs-string">"自定义选项"</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">div</span> <span class="hljs-attr">class</span>=<span class="hljs-string">"user-style"</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-cell</span>></span>\n 设置为默认 <span class="hljs-tag"><<span class="hljs-name">nut-switch</span>></span><span class="hljs-tag"></<span class="hljs-name">nut-switch</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-cell</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-cell</span>></span>\n <span class="hljs-tag"><<span class="hljs-name">nut-button</span> <span class="hljs-attr">size</span>=<span class="hljs-string">"large"</span> <span class="hljs-attr">type</span>=<span class="hljs-string">"primary"</span>></span>确认提交<span class="hljs-tag"></<span class="hljs-name">nut-button</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-cell</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">div</span>></span>\n <span class="hljs-tag"></<span class="hljs-name">nut-menu-item</span>></span>\n<span class="hljs-tag"></<span class="hljs-name">nut-menu</span>></span>\n</code></pre><h2>API</h2><h3>Props</h3><table><thead><tr><th>参数</th><th>说明</th><th>类型</th><th>默认值</th></tr></thead><tbody><tr><td>title</td><td>菜单标题名称或可为菜单列表第一项,必填</td><td>String</td><td>-</td></tr><tr><td>menu-list</td><td>菜单列表数据,必填</td><td>Array</td><td>-</td></tr><tr><td>multi-style</td><td>列表列数设置,默认1列,可选值 <code>1</code> <code>2</code> <code>3</code></td><td>String, Number</td><td>1</td></tr><tr><td>disabled</td><td>是否开启禁用设置,默认不开启</td><td>Boolean</td><td>false</td></tr><tr><td>max-height</td><td>菜单列表最大高度,单位px</td><td>String, Number</td><td>-</td></tr><tr><td>auto-close</td><td>选择后下拉菜单列表是否自动收起,默认自动收起</td><td>Boolean</td><td>true</td></tr><tr><td>has-mask</td><td>是否有蒙层</td><td>Boolean</td><td>true</td></tr></tbody></table><h3>Events</h3><table><thead><tr><th>事件名</th><th>说明</th><th>回调参数</th></tr></thead><tbody><tr><td>menu-click</td><td>点击菜单标题触发,返回菜单标题名称</td><td>event: Event</td></tr><tr><td>change</td><td>点击菜单列表选项触发,返回选中菜单项数据、名称</td><td>event: Event</td></tr></tbody></table>',30)];s("default",{setup:(s,{expose:t})=>(t({frontmatter:{}}),(s,t)=>(n(),a("div",l,p)))})}}}));
|