lee-ui(vue版本)

開始動手寫vue ui庫

創建vue項目

可以利用現成的vue-cli腳手架創建項目結構

vue init webpack XXX
cd XXX
yarn  // or npm install
npm run dev

到此為止,一個普通的vue項目就創建成功,接下來需要改變一下現有的目錄結構。

更改目錄結構

.
...
|-- examples  //原src目錄改成examples用作示例展示
|-- packages //新增 packages用于組件編寫目錄
...
.

這樣改完之后項目是直接跑不起來的,需要改下webpack的配置,打開./build/webpack.base.conf.js,將里面所有有關src的位置改成examples。大致有下面幾個位置需要修改:

1、
const createLintingRule = () => ({
  test: /\.(js|vue)$/,
  loader: 'eslint-loader',
  enforce: 'pre',
  include: [resolve('examples'), resolve('test')],  //這里的src改成examples
  options: {
    formatter: require('eslint-friendly-formatter'),
    emitWarning: !config.dev.showEslintErrorsInOverlay
  }
})
2、
entry: {
  app: './examples/main.js'  // 入口文件改成examples目錄
},
3、
resolve: {
  extensions: ['.js', '.vue', '.json'],
  alias: {
    'vue$': 'vue/dist/vue.esm.js',
    '@': resolve('examples'),  //將@解釋成examples
  }
}
4、
{
  test: /\.js$/,
  loader: 'babel-loader',
  include: [resolve('examples'), resolve('test')]
}

最后為了最后 npm run build能正常編譯packages,我們需要為babel-loader增加一個規則

{
   test: /\.js$/,
   loader: 'babel-loader',
   include: [resolve('examples'), resolve('test'), resolve('packages')]
}

這時候,再運行 npm run build就能正常打包了,但是有個問題,打包出來的文件直接運行會報404錯誤,這是因為打包的根目錄設置有問題,打開./config/index.js,找到build下面的assetsPublicPath: '/',改成如下即可

assetsPublicPath: './'

編寫文檔

一個好的ui庫,說明文檔自然是不可或缺的,然而markdown是最合適不過的,然而我們現在是一個vue項目,怎樣再vue項目里面用markdown來編寫文檔呢?答案是:vue-markdown-loader打開如上鏈接,按照里面的說明文檔配置webpack

npm i vue-markdown-loader -D

安裝完成之后修改webpack.base.config.js文件,在rules下面添加一條

{
  test: /\.md$/,
  loader: 'vue-markdown-loader'
}

接下來創建文件./examples/docs/home.md

## 這是首頁
::: demo
``` html
<div class="input">
  <input type="text" placeholder="請輸入用戶名"/>
</div>

修改router/index.js,將路由中的vue文件路徑改成markdown的路徑

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)

export default new Router({
  routes: [
    {
      path: '/',
      name: 'home',
      component: r => require.ensure([], () => r(require('../docs/home.md')))
    }
  ]
})

提示: 如果當你運行項目的時候遇到如下的報錯,你需要重新運行一下 yarn 或者npm install

'webpack-dev-server' 不是內部或外部命令,也不是可運行的程序
或批處理文件。

這時候再次運行項目,應該可以看到剛才markdown中的內容!但是我們的說明文檔可不止止是文字,鏈接,圖片這么簡單,我們還需要案例展示和代碼展示,接下來,我們需要配置vue-mark-down的option選項

const MarkdownItContainer = require('markdown-it-container')
const striptags = require('./strip-tags')

const vueMarkdown = {
  preprocess: (MarkdownIt, source) => {
    MarkdownIt.renderer.rules.table_open = function () {
      return '<table class="table">'
    }
    MarkdownIt.renderer.rules.fence = utils.wrapCustomClass(MarkdownIt.renderer.rules.fence)
    return source
  },
  use: [
    [MarkdownItContainer, 'demo', {
      // 用于校驗包含demo的代碼塊
      validate: params => params.trim().match(/^demo\s*(.*)$/),
      render: function(tokens, idx) {

        var m = tokens[idx].info.trim().match(/^demo\s*(.*)$/);

        if (tokens[idx].nesting === 1) {
          var desc = tokens[idx + 2].content;
          // 編譯成html
          const html = utils.convertHtml(striptags(tokens[idx + 1].content, 'script'))
          // 移除描述,防止被添加到代碼塊
          tokens[idx + 2].children = [];

          return `<demo-block>
                        <div slot="desc">${html}</div>
                        <div slot="highlight">`;
        }
        return '</div></demo-block>\n';
      }
    }]
  ]
}

將上面的這個變量放在./build/webpack.base.config.js中并修改如下

{
  test: /\.md$/,
  loader: 'vue-markdown-loader',
  options: vueMarkdown
}

在./build/utils.js中添加如下

/**
 * 增加 hljs 的 classname
 */
exports.wrapCustomClass = function (render) {
  return function (...args) {
    return render(...args)
      .replace('<code class="', '<code class="hljs ')
      .replace('<code>', '<code class="hljs">')
  }
}

/**
 * Format HTML string
 */
exports.convertHtml = function (str) {
  return str.replace(/(&#x)(\w{4});/gi, $0 => String.fromCharCode(parseInt(encodeURIComponent($0).replace(/(%26%23x)(\w{4})(%3B)/g, '$2'), 16)))
}

新增./build/strip-tags.js

/**
 * 轉換成DOM字符串
 */
const cheerio = require('cheerio')

module.exports = (str, tags) => {
  const $ = cheerio.load(str, { decodeEntities: false })

  if (!tags || tags.length === 0) {
    return str
  }

  tags = !Array.isArray(tags) ? [tags] : tags
  let len = tags.length

  while (len--) {
    $(tags[len]).remove()
  }

  return $.html()
}

上面都準備好了之后,我們需要安裝相應的依賴

npm i markdown-it-container --save-dev

到此之后我們便可以看到markdown文件中既可以展示文字,代碼,還可以展示可交互的輸入框等等。但是這時候,頁面中的代碼并沒有顯示代碼高亮,其實我們的頁面元素已經有了代碼高亮,只是沒有引用css文件,只需要將 node_modules/highlight.js/styles/color-brewer.css引入到項目中即可,接下來就是全心全意的寫插件了。

未完待續!

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容