{"id":560,"date":"2024-01-13T18:58:10","date_gmt":"2024-01-13T10:58:10","guid":{"rendered":"https:\/\/fugary.com\/?p=560"},"modified":"2024-01-13T20:09:09","modified_gmt":"2024-01-13T12:09:09","slug":"%e4%bb%8e%e9%9b%b6%e6%90%ad%e5%bb%ba%e5%9f%ba%e4%ba%8eelement-plus%e7%9a%84vue3%e9%a1%b9%e7%9b%ae05-%e7%bb%9f%e4%b8%80%e5%9b%be%e6%a0%87%e5%b0%81%e8%a3%85","status":"publish","type":"post","link":"https:\/\/fugary.com\/?p=560","title":{"rendered":"\u4ece\u96f6\u642d\u5efa\u57fa\u4e8eelement-plus\u7684Vue3\u9879\u76ee05\u2014\u2014\u7edf\u4e00\u56fe\u6807\u5c01\u88c5"},"content":{"rendered":"<p><code>element-plus<\/code>\u5df2\u7ecf\u81ea\u5e26\u90e8\u5206\u56fe\u6807\uff0c\u4e0d\u8fc7\u56fe\u6807\u6570\u91cf\u5e76\u4e0d\u591a\uff0c\u56e0\u4e3a\u662f\u540e\u53f0\u7cfb\u7edf\uff0c\u53ef\u4ee5\u8003\u8651\u96c6\u6210\u66f4\u591a\u7684\u56fe\u6807\uff0c\u8fd9\u91cc\u9009\u62e9<code>xicons<\/code>\u56fe\u6807\u5e93\u91cc\u9762\u7684<code>material<\/code>\u56fe\u6807\u5e93\u3002<\/p>\n<p>\u76ee\u524d\u56fe\u6807\u5e93\u57fa\u672c\u90fd\u662f\u7528\u7ec4\u4ef6\u7684\u5f62\u5f0f\u6765\u4f7f\u7528\u56fe\u6807\uff0c\u5f00\u59cb\u5df2\u7ecf\u96c6\u6210\u4e86<code>element-plus<\/code>\u7684\u56fe\u6807\uff0c\u8fd9\u91cc\u8981\u5b89\u88c5<code>xicons<\/code>\u3002<\/p>\n<p>\u5730\u5740\uff1a<a href=\"https:\/\/www.xicons.org\/\">https:\/\/www.xicons.org\/<\/a>#\/<\/p>\n<h3>\u5b89\u88c5xicons\u56fe\u6807<\/h3>\n<p>\u6839\u636e\u6587\u6863\uff0c\u9009\u62e9\u5b89\u88c5\uff1a<a href=\"https:\/\/github.com\/07akioni\/xicons#installation\">https:\/\/github.com\/07akioni\/xicons#installation<\/a><\/p>\n<p>\u5b89\u88c5\uff1a<code>npm i @vicons\/material<\/code><\/p>\n<h3>\u6ce8\u518c\u7ec4\u4ef6<\/h3>\n<p>\u5b89\u88c5\u4e4b\u540e\u7edf\u4e00\u6ce8\u518c\u5230<code>app<\/code>\u4e2d\uff0c\u8fd9\u91cc\u4ee5\u63d2\u4ef6\u7684\u5f62\u5f0f\u6ce8\u518c\u7ec4\u4ef6\uff0c\u6ce8\u518c\u6210<code>icon-xxx<\/code>\u7684\u5f62\u5f0f\uff0c\u5982\u679c\u9047\u5230\u540c\u540d\u7684\u56fe\u6807\uff0c\u52a0\u4e0a\u4e00\u4e2a\u524d\u7f00\u533a\u5206\uff1a<\/p>\n<pre><code class=\"language-js\">import * as ElementPlusIconsVue from &#039;@element-plus\/icons-vue&#039; \/\/ element\u56fe\u6807\nimport * as MaterialIconsVue from &#039;@vicons\/material&#039; \/\/ xicons\u7684material\u56fe\u6807\nimport kebabCase from &#039;lodash\/kebabCase&#039;\n\nexport const INSTALL_ICONS = []\nexport const ICON_PREFIX = &#039;icon-&#039;\n\nconst registryIconComponent = (app, key, component, prefix) =&gt; {\n  let componentName = `${ICON_PREFIX}${kebabCase(key)}` \/\/ \u7ec4\u4ef6\u540d\u5b57\n  if (app.component(componentName)) {\n    key = `${prefix}${key}`\n    componentName = `${ICON_PREFIX}${kebabCase(key)}`\n  }\n  INSTALL_ICONS.push(key)\n  app.component(componentName, component)\n}\n\nexport default {\n  install (app) {\n    for (const [key, component] of Object.entries(ElementPlusIconsVue)) {\n      registryIconComponent(app, key, component, &#039;El&#039;)\n    }\n    for (const [key, component] of Object.entries(MaterialIconsVue)) {\n      registryIconComponent(app, key, component, &#039;Md&#039;)\n    }\n  }\n}\n<\/code><\/pre>\n<p>\u5728main.js\u4e2d\u5f15\u5165\u5e76use\u5c31\u53ef\u4ee5\u4e86\uff1a<\/p>\n<pre><code>app.use(icons)<\/code><\/pre>\n<h3>\u56fe\u6807\u641c\u7d22\u5de5\u5177<\/h3>\n<p>\u56fe\u6807\u6570\u91cf\u5f88\u591a\uff0c\u5982\u679c\u76f4\u63a5\u628a\u6240\u6709\u56fe\u6807\u5217\u5728\u9875\u9762\u4e0a\u4f7f\u7528\u4f1a\u6709\u6027\u80fd\u95ee\u9898\uff0c\u56e0\u6b64\u4f7f\u7528<code>vue-virtual-scroller<\/code>\u865a\u62df\u6eda\u5c4f\u6765\u63d0\u5347\u6027\u80fd\u3002<\/p>\n<h4>\u5b89\u88c5vue-virtual-scroller<\/h4>\n<p>\u5b89\u88c5\uff1a<code>npm install --save vue-virtual-scroller<\/code><\/p>\n<p>\u5730\u5740\uff1a<a href=\"https:\/\/www.npmjs.com\/package\/vue-virtual-scroller\">https:\/\/www.npmjs.com\/package\/vue-virtual-scroller<\/a><\/p>\n<p>\u5728main.js\u4e2d\u5f15\u5165\uff1a<\/p>\n<pre><code class=\"language-js\">import VueVirtualScroller from &#039;vue-virtual-scroller&#039;\nimport &#039;vue-virtual-scroller\/dist\/vue-virtual-scroller.css&#039;\n\nVue.use(VueVirtualScroller)<\/code><\/pre>\n<h4>\u56fe\u6807\u641c\u7d22\u9875\u9762<\/h4>\n<p>\u9875\u9762\u901a\u8fc7\u540d\u5b57\u5173\u952e\u5b57\u8fc7\u6ee4\u56fe\u6807\uff0c\u9009\u62e9\u56fe\u6807\u540e\u7528<code>vueuse<\/code>\u63d0\u4f9b\u7684<code>useClipboard<\/code>\u6765\u590d\u5236\u6570\u636e\uff0c\u5927\u6570\u636e\u91cf\u7528<code>recycle-scroller<\/code>\u6765\u52a0\u901f\uff0c\u5426\u5219\u9875\u9762\u4f1a\u5361\u6b7b\u3002<\/p>\n<pre><code class=\"language-html\">&lt;script setup&gt;\nimport { computed, ref } from &#039;vue&#039;\nimport { useClipboard } from &#039;@vueuse\/core&#039;\nimport { ElMessage } from &#039;element-plus&#039;\nimport { filterIconsByKeywords } from &#039;@\/services\/icon\/IconService&#039;\n\nconst colSize = ref(8)\nconst keyWords = ref(&#039;&#039;)\n\nconst filterIcons = computed(() =&gt; {\n  return filterIconsByKeywords(keyWords.value, colSize.value)\n})\n\nconst copyIcon = (icon) =&gt; {\n  const { copy, isSupported } = useClipboard()\n  const iconStr = `&lt;common-icon icon=&quot;${icon}&quot;\/&gt;`\n  if (isSupported) {\n    copy(iconStr)\n    ElMessage({\n      message: `Copied: ${iconStr}`,\n      type: &#039;success&#039;\n    })\n  } else {\n    ElMessage({\n      message: `Copy Not supported: ${iconStr}`,\n      type: &#039;error&#039;\n    })\n  }\n}\n\n&lt;\/script&gt;\n\n&lt;template&gt;\n  &lt;el-container\n    class=&quot;icon-container&quot;\n  &gt;\n    &lt;el-header height=&quot;40px&quot;&gt;\n      &lt;el-form label-width=&quot;120px&quot;&gt;\n        &lt;el-form-item :label=&quot;$t(&#039;common.label.keywords&#039;)&quot;&gt;\n          &lt;el-input\n            v-model=&quot;keyWords&quot;\n            :placeholder=&quot;$t(&#039;common.msg.inputKeywords&#039;)&quot;\n          \/&gt;\n        &lt;\/el-form-item&gt;\n      &lt;\/el-form&gt;\n    &lt;\/el-header&gt;\n    &lt;el-main&gt;\n      &lt;recycle-scroller\n        v-slot=&quot;{ item }&quot;\n        class=&quot;scroller icon-list&quot;\n        :items=&quot;filterIcons&quot;\n        :item-size=&quot;80&quot;\n        key-field=&quot;id&quot;\n      &gt;\n        &lt;el-row&gt;\n          &lt;el-col\n            v-for=&quot;icon in item.icons&quot;\n            :key=&quot;icon&quot;\n            :span=&quot;24\/colSize&quot;\n            class=&quot;text-center&quot;\n          &gt;\n            &lt;a\n              class=&quot;el-button el-button--large is-text icon-a&quot;\n              @click=&quot;copyIcon(icon)&quot;\n            &gt;\n              &lt;div&gt;\n                &lt;common-icon\n                  size=&quot;20&quot;\n                  :icon=&quot;icon&quot;\n                \/&gt;\n                &lt;br&gt;\n                &lt;span class=&quot;icon-text&quot;&gt;{{ icon }}&lt;\/span&gt;\n              &lt;\/div&gt;\n            &lt;\/a&gt;\n          &lt;\/el-col&gt;\n        &lt;\/el-row&gt;\n      &lt;\/recycle-scroller&gt;\n    &lt;\/el-main&gt;\n  &lt;\/el-container&gt;\n&lt;\/template&gt;\n\n&lt;style scoped&gt;\n.scroller, .icon-container  {\n  height: 100%;\n}\n.icon-container .el-input {\n  width: 80%;\n}\n.icon-a {\n  height:80px;\n  display: block;\n  width:100%;\n  overflow:hidden;\n  padding: 15px 10px;\n}\n.icon-a span {\n  font-size: 12px;\n}\n&lt;\/style&gt;\n<\/code><\/pre>\n<p><div class='fancybox-wrapper' data-fancybox='post-images' href='https:\/\/git.mengqingpo.com:8888\/\/fugary\/blogpic\/uploads\/25af410c3b37e50fa0a5163e2249fbe3\/image-20240113185604731.png'><img src=\"https:\/\/git.mengqingpo.com:8888\/\/fugary\/blogpic\/uploads\/25af410c3b37e50fa0a5163e2249fbe3\/image-20240113185604731.png\" alt=\"image-20240113185604731\" \/><\/div><\/p>\n<h3>\u56fe\u6807\u4f7f\u7528\u5305\u88c5<\/h3>\n<p>\u4e3a\u4e86\u65b9\u4fbf\u4f7f\u7528\uff0c\u7edf\u4e00\u5c01\u88c5\u4e00\u4e2a<code>common-icon<\/code>\u7ec4\u4ef6\uff0c\u5728<code>el-icon<\/code>\u57fa\u7840\u4e0a\u5305\u88c5\u4e00\u5c42\uff0c\u7edf\u4e00\u4f7f\u7528\u56fe\u6807\u7ec4\u4ef6<\/p>\n<pre><code class=\"language-html\">&lt;script setup&gt;\nimport { computed } from &#039;vue&#039;\nimport { ICON_PREFIX } from &#039;@\/icons&#039;\nimport kebabCase from &#039;lodash\/kebabCase&#039;\n\nconst props = defineProps({\n  icon: {\n    type: String,\n    required: false\n  }\n})\nconst calcIcon = computed(() =&gt; {\n  if (props.icon) {\n    return `${ICON_PREFIX}${kebabCase(props.icon)}`\n  }\n  return props.icon\n})\n&lt;\/script&gt;\n\n&lt;template&gt;\n  &lt;el-icon\n    v-if=&quot;calcIcon&quot;\n    v-bind=&quot;$attrs&quot;\n  &gt;\n    &lt;component\n      :is=&quot;calcIcon&quot;\n    \/&gt;\n  &lt;\/el-icon&gt;\n&lt;\/template&gt;\n<\/code><\/pre>\n<p>\u4f7f\u7528\uff1a<\/p>\n<pre><code class=\"language-html\">&lt;common-icon icon=&quot;HomeFilled&quot;\/&gt;<\/code><\/pre>\n<p>\u6700\u7ec8\u5f00\u6e90\u5730\u5740\uff1a<\/p>\n<p><a href=\"https:\/\/github.com\/fugary\/simple-element-plus-template\">https:\/\/github.com\/fugary\/simple-element-plus-template<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>element-plus\u5df2\u7ecf\u81ea\u5e26\u90e8\u5206\u56fe\u6807\uff0c\u4e0d\u8fc7\u56fe\u6807\u6570\u91cf\u5e76\u4e0d\u591a\uff0c\u56e0\u4e3a\u662f\u540e\u53f0\u7cfb\u7edf\uff0c\u53ef\u4ee5\u8003\u8651\u96c6\u6210\u66f4\u591a\u7684\u56fe\u6807\uff0c\u8fd9\u91cc\u9009\u62e9 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[6],"tags":[139,141,10,136,140],"_links":{"self":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/560"}],"collection":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=560"}],"version-history":[{"count":2,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/560\/revisions"}],"predecessor-version":[{"id":569,"href":"https:\/\/fugary.com\/index.php?rest_route=\/wp\/v2\/posts\/560\/revisions\/569"}],"wp:attachment":[{"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=560"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=560"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fugary.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=560"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}