亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 幫助中心 > 正文

vue遠程加載sfc組件思路詳解

2024-07-09 22:42:50
字體:
來源:轉載
供稿:網友

問題

在我們的 vue 項目中(特別是后臺系統),總會出現一些需要多業務線共同開發同一個項目的場景,如果各業務團隊向項目中提供一些公共業務組件,但是這些組件并不能和項目一起打包,因為項目中不能因為某個私有模塊的頻繁變更而重復構建發布。

^_^不建議在生產環境使用,代碼包含eval 

思路

在這種場景下我們需要將公共的業務組件部署到服務端,由客戶端請求并渲染組件。

服務端解析.vue文件

使用vue-template-compiler 模板解析器,解析SFC(單文件組件)

const compile = require('vue-template-compiler')// 獲取sfc組件的源碼const str = fs.readFileSync(path.resolve(__dirname, `../components/sfc.vue`), 'utf-8')// vue-loader內置,現在用來解析SFC(單文件組件)let sfc = compile.parseComponent(str)// 獲取sfc組件配置let sfcOptions = getComponentOption(sfc)

getComponentOption 獲取sfc組件配置

import { uuid } from 'utilscore'import stylus from 'stylus'import sass from 'sass'import less from 'less'const getComponentOption = sfc => {  // 生成data-u-id   const componentId = uuid(8, 16).toLocaleLowerCase()    // 標簽添加data-u-id屬性    const template = sfc.template ? tagToUuid(sfc.template.content, componentId) : ''    // 轉化style(less、sass、stylus)    let styles = []    sfc.styles.forEach(sty => {        switch (sty.lang) {            case 'stylus':                stylus.render(sty.content, (err, css) => styles.push(formatStyl(sty, css, componentId)))                break;            case 'sass':            case 'scss':                styles.push(formatStyl(sty, sass.renderSync({ data: sty.content }).css.toString(), componentId))                break;            case 'less':                less.render(sty.content, (err, css) => styles.push(formatStyl(sty, css, componentId)))                break;        }    })    let options = {        script: sfc.script ? $require(null, sfc.script.content) : {},        styles,        template    }    return JSON.stringify(options, (k, v) => {    if(typeof(v) === 'function') {      let _fn = v.toString()      return /^function()/.test(_fn) ? _fn : fn.replace(/^/,'function ')    }    return v  })}

tagToUuid  給template 中的標簽追加data-u-id 

const tagToUuid = (tpl, id) => {    var pattern = /<[^//]("[^"]*"|'[^']*'|[^'">])*>/g    return tpl.replace(pattern, $1 => {        return $1.replace(/<([/w/-]+)/i, ($2, $3) => `<${$3} data-u-${id}`)    })}

formatStyl 處理樣式的scoped

const formatStyl = (sty, css, componentId) => {    let cssText = css    if (sty.scoped) {        cssText = css.replace(/[/./w/>/s]+{/g, $1 => {          if (/>>>/.test($1)) return $1.replace(//s+>>>/, `[data-u-${componentId}]`)          return $1.replace(//s+{/g, $2 => `[data-u-${componentId}]${$2}`)        })    }    return cssText}

$require 執行其中的的 JavaScript 代碼,并返回值

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产免费av| 国产视频在线观看一区二区| 亚洲精品自在久久| 国产精品中文字幕在线观看| 成人av电影天堂| 国产三级精品网站| 91免费人成网站在线观看18| 日韩中文在线不卡| 91欧美激情另类亚洲| 亚洲美女www午夜| 欧美丰满少妇xxxxx| 5566成人精品视频免费| 亚洲欧美日韩直播| 一本大道久久加勒比香蕉| 高清欧美性猛交xxxx| 伦伦影院午夜日韩欧美限制| 日韩av毛片网| 黑人巨大精品欧美一区二区三区| 欧美综合国产精品久久丁香| 视频直播国产精品| 久久偷看各类女兵18女厕嘘嘘| 777午夜精品福利在线观看| 精品久久久久久久久久ntr影视| 欧美午夜xxx| 伊人男人综合视频网| 成人免费看片视频| 不卡在线观看电视剧完整版| 日韩av免费看| 久久影院资源站| 91在线观看免费高清| 亚洲自拍av在线| 国产精品第三页| 久久免费视频这里只有精品| 色综合久久88色综合天天看泰| 久久夜色精品国产| 日韩av免费在线观看| 亚洲午夜国产成人av电影男同| 人人澡人人澡人人看欧美| 亚洲精品综合久久中文字幕| 日韩av高清不卡| 亚洲国产又黄又爽女人高潮的| 久热在线中文字幕色999舞| 亲爱的老师9免费观看全集电视剧| 国产精品久久999| 成人免费看吃奶视频网站| 日韩欧美亚洲成人| 日韩欧美精品免费在线| 欧美另类极品videosbest最新版本| 欧美激情免费视频| 日韩精品在线免费| 久久伊人免费视频| 精品亚洲男同gayvideo网站| 欧美日韩精品在线观看| 久久久久久综合网天天| 日韩中文字幕网站| 日本成人精品在线| 亚洲精品之草原avav久久| 92看片淫黄大片看国产片| 性欧美xxxx| 欧美理论在线观看| 亚洲无线码在线一区观看| 日本中文字幕不卡免费| 亚洲人成亚洲人成在线观看| 国产精品视频精品视频| 国产精品网站入口| 亚洲欧美另类国产| 久久手机精品视频| 亚洲国产精品va在线看黑人动漫| 亚洲精品国产欧美| 欧美人与物videos| 欧美特级www| 国产精品精品一区二区三区午夜版| 91精品国产高清久久久久久91| 国产成+人+综合+亚洲欧美丁香花| 高清欧美性猛交xxxx黑人猛交| 国产精品成久久久久三级| 日韩亚洲欧美中文在线| 欧美日韩福利在线观看| 久久精品99久久久久久久久| 久久精品人人做人人爽| 亚洲成人黄色网| 国产精品吹潮在线观看| 欧美日韩精品中文字幕| 欧美巨猛xxxx猛交黑人97人| 亚洲深夜福利视频| 91色p视频在线| 97国产精品人人爽人人做| 深夜福利一区二区| 精品国产欧美一区二区三区成人| 国产亚洲精品激情久久| 永久免费毛片在线播放不卡| 亚洲第一页中文字幕| 亚洲毛茸茸少妇高潮呻吟| 欧美激情第三页| 久久免费视频在线观看| 亚洲www在线观看| 米奇精品一区二区三区在线观看| 国产精品高潮呻吟久久av野狼| 2020国产精品视频| 亚洲精品久久视频| 92看片淫黄大片欧美看国产片| 欧美亚洲视频在线看网址| 国内精品中文字幕| 国产日韩欧美91| 高清亚洲成在人网站天堂| 深夜福利亚洲导航| 成人欧美一区二区三区黑人孕妇| 亚洲欧美综合另类中字| 97在线看免费观看视频在线观看| 亚洲最大av网站| 全球成人中文在线| 91精品国产免费久久久久久| 伊人久久久久久久久久| 亚洲女人天堂av| 日韩av一区二区在线| 国产精品久久久久福利| 国产日韩欧美一二三区| 久久久久国产精品一区| 精品少妇v888av| 欧美多人乱p欧美4p久久| 热门国产精品亚洲第一区在线| 欧美亚洲一级片| 韩国v欧美v日本v亚洲| 亚洲精品自拍第一页| 日韩av网站在线| 国产精品一区二区三区免费视频| 欧美天堂在线观看| 狠狠躁夜夜躁人人爽超碰91| xx视频.9999.com| 国产精品亚洲综合天堂夜夜| 亚洲精品乱码久久久久久金桔影视| 日韩国产高清污视频在线观看| 亚洲成人网在线| 亚洲一区中文字幕| 中文字幕国产精品久久| 亚洲r级在线观看| 欧美日韩精品中文字幕| 国产精品爽黄69| 美女av一区二区三区| 91久久夜色精品国产网站| 国产精品欧美日韩| 性亚洲最疯狂xxxx高清| 日韩视频在线免费观看| 久久五月天色综合| 精品久久久一区| 欧美精品中文字幕一区| 国产mv免费观看入口亚洲| 国产91精品黑色丝袜高跟鞋| 国产成人精品在线| 色综合天天狠天天透天天伊人| 亚洲国产一区二区三区在线观看| 一区二区三区在线播放欧美| 欧美日韩免费在线| 国产精品丝袜高跟| 亚洲天堂男人天堂女人天堂| 亚洲一区二区在线播放| 国产一区二区三区在线观看网站| 欧美性受xxxx白人性爽| 久久久97精品| 久久久久免费精品国产| 中文字幕精品一区二区精品| 亚洲va码欧洲m码| 色777狠狠综合秋免鲁丝| 九九精品视频在线|