精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

手把手教你實現一個簡易的Vue組件在線編輯器

開發
vue-cli使用過vue的我想大家都知道,那么xxx.vue組件是怎么運行的呢?怎么把template,script,style渲染到頁面上的呢?今天我們手動寫了個簡易的Vue組件在線編輯器玩一玩。

 [[357690]]

vue-cli使用過vue的我想大家都知道,那么xxx.vue組件是怎么運行的呢?怎么把template,script,style渲染到頁面上的呢?今天我們手動寫了個簡易的Vue組件在線編輯器玩一玩。

話不多說先看一下效果


準備工作

  1. 安裝vuejs
  2. 新建xxx.html
  3. 新建xxx.css

編寫頁面

  1. <div id="app"
  2.        <textarea name="" id="" cols="30" rows="30" v-model="content" autofocus placeholder="請輸入vue模板"></textarea> 
  3.        <div class="btn-center"
  4.            <button @click="run">運行代碼</button> 
  5.            <button @click="reset">清除</button> 
  6.        </div> 
  7.    </div> 
  8.    <div id="result"></div> 
  9.    <script src="./node_modules/vue/dist/vue.js"></script> 
textarea 元素為vue組件代碼的編寫部分,button為按鈕區域
  1. textarea { 
  2.             display: block; 
  3.             width: 100%; 
  4.             min-height: 100px; 
  5.             max-height: 500px; 
  6.             padding: 8px; 
  7.             resize: auto; 
  8.  } 
  9.  
  10.  button { 
  11.             margin-top: 8px; 
  12.             display: inline-block; 
  13.             padding: 5px 16px; 
  14.             font-size: 14px; 
  15.             font-weight: 500; 
  16.             line-height: 20px; 
  17.             white-space: nowrap; 
  18.             vertical-align: middle; 
  19.             cursor: pointer; 
  20.             -webkit-user-select: none; 
  21.             -moz-user-select: none; 
  22.             -ms-user-select: none; 
  23.             user-select: none; 
  24.             border: 1px solid; 
  25.             border-radius: 6px; 
  26.             -webkit-appearance: none; 
  27.             -moz-appearance: none; 
  28.             appearance: none; 
  29.  .btn-center{ 
  30.            text-align: center; 
  31.  } 

思路分解

在xxx.vue中,我們寫組件通常遵循一下模板

  1. <template> 
  2.      
  3. </template> 
  4. <script> 
  5. export default { 
  6.      
  7. </script> 
  8. <style> 
  9.  
  10. </style> 

我們想到的是在拿到輸入的內容之后,我們希望獲取都tempalte,script,style中的內容,然后通過Vue.extend( options )方法掛載到頁面的元素上即可。

解析標簽

我們需要拿到內容包括下圖紅圈外的部分


可以利用字符串的match方法獲取到每一段的開始標簽的下標,開始標簽的長度以及結束標簽的下標,然后通過slice方法截取獲取到想要的內容。

  1. getSource(type){ 
  2.     const reg = new RegExp(`<${type}[^>]*>`); 
  3.     let content = this.content; 
  4.     let matches = content.match(reg); 
  5.     if(matches){ 
  6.       let start = content.indexOf(matches[0])+matches[0].length; 
  7.       let end = content.lastIndexOf(`</${type}`); 
  8.       return content.slice(start,end
  9.     } 
  10.   }, 

截取之后獲取到的結果


轉化函數


在vue官網中,data必須是一個函數,我們拿到的是一個字符串

  1. export default { 
  2.     data(){ 
  3.         return { 
  4.             msg:'hello world' 
  5.         } 
  6.     }, 
  7.     methods:{ 
  8.         run(){ 
  9.             console.log("你好"
  10.         } 
  11.     } 

如何把一個字符串轉化為可執行函數,可以參考如何讓一個字符串執行?

我們可以用new Function方法將字符串轉化為可執行函數,我們需要的是

  1. data(){ 
  2.         return { 
  3.             msg:'hello world' 
  4.         } 
  5.     }, 
  6.     methods:{ 
  7.         run(){ 
  8.             console.log("你好"
  9.         } 
  10.     } 

利用字符串的replace方法將export default 替換成return得到


完成代碼

  1. run:function(){ 
  2.  let template = this.getSource("template"); 
  3.  if(!template) return 
  4.  let script = this.getSource("script"); 
  5.  if(script){ 
  6.    script = script.replace(/export default/,"return"); 
  7.  } 
  8.  let obj = new Function(script)(); 
  9.  obj.template = template; 
  10.  let Profile = Vue.extend(obj); 
  11.  new Profile().$mount("#result"
  12. }, 

處理樣式

通過正則解析拿到style樣式之后,添加到head中即可

  1. let styleCss = this.getSource("style"); 
  2. let style = document.createElement("style"); 
  3. style.innerHTML = styleCss; 
  4. document.head.appendChild(style); 

總結

以上就是本文的全部內容了,只是簡單地借助Vue.extend()方法實現的一個簡單的Vue組件在線編輯器

  1. <div id="app"
  2.     <textarea name="" id="" cols="30" rows="30" v-model="content" autofocus placeholder="請輸入vue模板"></textarea> 
  3.     <div class="btn-center"
  4.         <button @click="run">運行代碼</button> 
  5.         <button @click="reset">清除</button> 
  6.     </div> 
  7. </div> 
  8. <div id="result"></div> 
  9. <script src="./node_modules/vue/dist/vue.js"></script> 
  10. <script> 
  11.     new Vue({ 
  12.         el: "#app"
  13.         data() { 
  14.             return { 
  15.                 content: "" 
  16.             } 
  17.         }, 
  18.         methods: { 
  19.             getSource(type) { 
  20.                 const reg = new RegExp(`<${type}[^>]*>`); 
  21.                 let content = this.content; 
  22.                 let matches = content.match(reg); 
  23.                 if (matches) { 
  24.                     let start = content.indexOf(matches[0]) + matches[0].length; 
  25.                     let end = content.lastIndexOf(`</${type}`); 
  26.                     console.log(content.slice(start, end)); 
  27.                     return content.slice(start, end
  28.                 } 
  29.             }, 
  30.             run: function () { 
  31.                 let template = this.getSource("template"); 
  32.                 if (!template) return 
  33.                 let script = this.getSource("script"); 
  34.                 if (script) { 
  35.                     script = script.replace(/export default/, "return"); 
  36.                 } 
  37.                 let styleCss = this.getSource("style"); 
  38.                 let style = document.createElement("style"); 
  39.                 style.innerHTML = styleCss; 
  40.                 document.head.appendChild(style); 
  41.                 let obj = new Function(script)(); 
  42.                 obj.template = template; 
  43.                 let Profile = Vue.extend(obj); 
  44.                 new Profile().$mount("#result"
  45.             }, 
  46.             reset() { 
  47.                 this.content = '' 
  48.             } 
  49.         } 
  50.     }) 
  51. </script> 

 

責任編輯:姜華 來源: 前端簡報
相關推薦

2022-09-22 12:38:46

antd form組件代碼

2022-06-28 15:29:56

Python編程語言計時器

2020-12-02 12:29:24

Vue無限級聯樹形

2022-08-26 08:01:38

DashWebJavaScrip

2021-06-22 10:43:03

Webpack loader plugin

2023-04-26 12:46:43

DockerSpringKubernetes

2021-11-10 11:40:42

數據加解密算法

2019-08-26 09:25:23

RedisJavaLinux

2009-11-09 14:57:37

WCF上傳文件

2011-01-06 10:39:25

.NET程序打包

2021-07-14 09:00:00

JavaFX開發應用

2011-05-03 15:59:00

黑盒打印機

2025-05-07 00:31:30

2011-01-10 14:41:26

2018-11-22 09:17:21

消息推送系統

2021-08-31 10:02:10

KubernetesLinux集群

2016-11-01 09:46:04

2021-07-12 09:03:50

Python任務管理器cmd命令

2016-05-12 11:54:39

2011-04-21 10:32:44

MySQL雙機同步
點贊
收藏

51CTO技術棧公眾號

婷婷综合激情网| 国产真实乱偷精品视频| 精品乱码一区二区三区四区| 亚洲精品一二三四区| 都市激情久久久久久久久久久| 西西44rtwww国产精品| 免费电影一区二区三区| 欧美人狂配大交3d怪物一区| 日韩av高清在线看片| av女优在线| 99久久久无码国产精品| 国产日本欧美一区| 日韩三级视频在线播放| 99久久精品国产亚洲精品 | 国产真实有声精品录音| 日韩无一区二区| 91av俱乐部| 91桃色在线观看| 国产精品不卡在线| 欧美激情导航| 丰满肉肉bbwwbbww| 久草在线在线精品观看| 国产91精品在线播放| 久久久久噜噜噜亚洲熟女综合| 国产欧美日韩影院| 欧美精品一区二区三区高清aⅴ| 鲁一鲁一鲁一鲁一av| 不卡视频观看| 亚洲黄色免费网站| 日本黄色播放器| 精品电影在线| 91天堂素人约啪| 成人三级视频在线观看一区二区| 在线观看视频中文字幕| 午夜在线a亚洲v天堂网2018| 欧美极品美女视频网站在线观看免费| 97在线观看免费高| 色狮一区二区三区四区视频| 亚洲天堂免费视频| 亚洲精品视频大全| 台湾亚洲精品一区二区tv| 欧美不卡在线视频| 欧美日韩一区二区区| 午夜不卡一区| 欧美日韩成人综合| 一本一道久久a久久综合蜜桃| 中文.日本.精品| 欧美天堂亚洲电影院在线播放| 久久网站免费视频| 极品在线视频| 欧美午夜久久久| 黄网站色视频免费观看| fc2ppv国产精品久久| 亚洲色图在线播放| 中国 免费 av| 在线播放蜜桃麻豆| 夜色激情一区二区| 青青草国产免费| 97蜜桃久久| 精品欧美一区二区三区| 国产91在线免费| 日韩在线伦理| 欧洲一区二区三区在线| 中文久久久久久| 日韩免费小视频| 欧美日韩一卡二卡三卡 | 99国产精品久久久久久久久久 | 日韩a一级欧美一级| 精品国模一区二区三区欧美| 日韩一区二区免费电影| 精品久久久久一区二区| 日韩电影在线观看完整免费观看| 亚洲精品福利在线观看| av电影网站在线观看| 成人激情在线| 美女性感视频久久久| 黄色激情视频在线观看| 性欧美长视频| 成人黄色片网站| 亚洲国产综合网| 91麻豆文化传媒在线观看| 日韩精品最新在线观看| 麻豆免费在线视频| 亚洲超碰97人人做人人爱| 激情综合网婷婷| 日本亚洲欧洲无免费码在线| 欧美大片一区二区| 欧美日韩高清丝袜| 中文字幕免费一区二区| 欧美亚洲伦理www| 亚洲一级特黄毛片| 岛国精品在线播放| 日韩在线电影一区| 另类视频在线| 欧美天天综合网| 亚洲一区二区在线免费| 欧美日韩一二三四| 麻豆国产精品va在线观看不卡| 日本妇女毛茸茸| 久久免费国产| 国产98在线|日韩| 福利在线视频导航| 亚洲成a人片在线不卡一二三区 | 国产一区二区三区欧美| 久久国产露脸精品国产| 日韩成人一区二区三区在线观看| 91精品综合久久| 91高清在线| 精品福利樱桃av导航| 天天久久综合网| 国产免费av一区二区三区| 欧美激情综合亚洲一二区| 一起草av在线| 久久久亚洲精品一区二区三区 | 久久精品国产久精国产爱| 国产手机精品在线| av中文字幕在线观看| 91传媒视频在线播放| 一级黄色片毛片| 中文字幕亚洲精品乱码 | 国产偷人爽久久久久久老妇app| 国产成人免费视频| 一本久道久久综合| 亚洲成人看片| 日韩毛片中文字幕| 69精品久久久| 国产成人精品免费视频网站| 一区二区精品视频| 四虎4545www国产精品| 日韩久久精品成人| 国产一区二区三区影院| 国产成人精品影院| 18视频在线观看娇喘| 久久精品超碰| 中文字幕久久精品| 一区二区三区麻豆| 久久久噜噜噜久久中文字幕色伊伊| 久久综合久久网| 亚洲精品午夜| 不卡av在线播放| www.五月婷| 亚洲欧美另类图片小说| 国产免费中文字幕| 亚洲成人精品| 亚洲aa中文字幕| caoporm免费视频在线| 777午夜精品视频在线播放| 男人av资源站| 黄页网站大全一区二区| 黑人巨大国产9丨视频| 玖玖玖电影综合影院| 美乳少妇欧美精品| 精品国产九九九| 亚洲一区二区三区在线看| 少妇愉情理伦片bd| 激情欧美一区| 精品午夜一区二区| 在线能看的av网址| 一本色道久久88综合日韩精品 | 亚洲欧美日韩在线综合| 国外成人福利视频| 欧美成人午夜激情在线| 亚洲av无码一区二区三区dv| 亚洲国产日日夜夜| 欧美成人三级伦在线观看| 亚洲欧美日韩在线观看a三区| 欧美日韩另类综合| 九九热这里有精品| 欧美成人精品h版在线观看| 成人激情四射网| 欧美日韩国产在线播放| 国产成人无码精品久久二区三| 免费成人在线网站| 亚洲小说欧美另类激情| 国产精品极品在线观看| 国产成人精品免高潮费视频| 91网页在线观看| 欧美成人a在线| 国产精品视频一区在线观看| 国产精品毛片大码女人| 制服.丝袜.亚洲.中文.综合懂| 亚洲精选在线| 亚洲7777| 国内精品麻豆美女在线播放视频| 奇米影视亚洲狠狠色| 色老头视频在线观看| 精品毛片乱码1区2区3区| 精品人妻一区二区三区潮喷在线| 国产精品国产a| 国产草草浮力影院| 久久91精品久久久久久秒播| 你真棒插曲来救救我在线观看| 成人6969www免费视频| 丁香五月网久久综合| 欧美片第1页| 久久国产精品久久国产精品| 邻家有女韩剧在线观看国语| 欧美高清视频不卡网| yjizz国产| 亚洲免费观看高清完整版在线 | 亚洲天堂网中文字| 国精产品一区一区三区免费视频| 国产一区二区三区视频在线播放| 免费av观看网址| 亚洲色图二区| 色姑娘综合av| 欧美黑白配在线| 91九色国产在线| 91精品xxx在线观看| 欧美黑人又粗大| 日本免费中文字幕在线| 精品五月天久久| 亚洲欧美强伦一区二区| 欧美日韩精品一区二区在线播放| 国产三级av片| 亚洲成av人片一区二区| wwwav国产| 亚洲欧洲另类国产综合| 一卡二卡三卡四卡| 成人动漫视频在线| 永久免费看片在线观看| 麻豆久久久久久久| 久久精品99国产| 亚洲久久一区二区| 国产女主播自拍| 国产精品99一区二区| 中文字幕中文字幕99| 欧州一区二区| 日韩欧美亚洲在线| 九九视频精品全部免费播放| 久久国产精品精品国产色婷婷| 亚洲国产欧美国产第一区| 成人免费视频a| 日日夜夜亚洲精品| 国产在线观看精品一区二区三区| 亚洲mmav| 国产综合视频在线观看| 国产资源一区| 国产日韩欧美另类| 四虎视频在线精品免费网址| 国产精品一区二区久久| 69堂精品视频在线播放| 国产精品普通话| 亚洲精品三区| 91视频88av| 日韩高清一区| 国产精品免费视频一区二区 | 精品国产第一福利网站| 日本国产精品视频| 欧美日韩亚洲国产| 国产精品永久免费视频| 黄页免费欧美| 成人情趣片在线观看免费| 欧美黄视频在线观看| 97视频中文字幕| 黑人久久a级毛片免费观看| 国产精品久久久久久久久久直播 | 日韩欧美视频一区二区三区四区| 精品影片在线观看的网站| 日韩中文字幕一区| 偷偷www综合久久久久久久| 久久视频免费在线| 亚洲香蕉网站| 久久无码高潮喷水| 日本午夜精品一区二区三区电影 | 久久视频中文字幕| 影音先锋在线播放| 97视频在线观看免费| xxxxxx欧美| 成人黄色av网| 国产精品极品| 天天久久人人| 欧美 日韩 国产一区二区在线视频| cao在线观看| 久久一区视频| 亚洲成人手机在线观看| 9i在线看片成人免费| 日本一级免费视频| 亚洲精品乱码久久久久| 中日韩精品视频在线观看| 欧美日韩久久久久久| 国产18精品乱码免费看| 亚洲人高潮女人毛茸茸| 国产成人无吗| 欧美一级片免费在线| 国产精品亚洲欧美日韩一区在线| 国产伦精品一区二区三区四区视频| 久久av综合| 精品无码av无码免费专区| 久久精品欧洲| 香蕉视频xxx| 久久精品视频免费观看| 国产精品丝袜一区二区| 日韩欧美亚洲一二三区| 国产同性人妖ts口直男| 亚洲欧美中文日韩在线v日本| 国产精品剧情| 国产精品99久久99久久久二8| 精品国产欧美| 欧洲久久久久久| 今天的高清视频免费播放成人| 欧美婷婷精品激情| av一二三不卡影片| 九九热视频在线免费观看| 日韩欧美国产黄色| 亚洲产国偷v产偷v自拍涩爱| 在线日韩欧美视频| 牛牛精品一区二区| 痴汉一区二区三区| 午夜精品视频一区二区三区在线看| 国产精品免费观看久久| 国产91色综合久久免费分享| 69xxx免费| 日本高清视频一区二区| 日韩中文字幕免费在线观看| 欧美成人精品激情在线观看| 国产又粗又长又硬| 香蕉久久夜色| 99久久.com| 爆乳熟妇一区二区三区霸乳| 成人白浆超碰人人人人| 国产一区二区视频在线观看免费| 在线观看欧美黄色| 青青青草原在线| 国内久久久精品| 日本少妇精品亚洲第一区| 亚洲草草视频| 日本最新不卡在线| 国产av自拍一区| 一本色道久久综合亚洲aⅴ蜜桃| 婷婷久久久久久| 欧美精品videos性欧美| 日韩一区二区三区高清在线观看| 永久久久久久| 久久精品99国产精品日本| 人与嘼交av免费| 欧美中文字幕一区| 国产日产精品久久久久久婷婷| 秋霞午夜一区二区| 中文有码一区| caopor在线视频| 久久精品在这里| 亚洲高清视频免费观看| 亚洲人成亚洲人成在线观看| 樱桃视频成人在线观看| 茄子视频成人在线观看| 久久一区中文字幕| 大黑人交xxx极品hd| 在线精品国精品国产尤物884a| 免费一级在线观看播放网址| 国产福利视频一区| 欧美日韩国产免费观看视频| 鲁一鲁一鲁一鲁一av| 亚洲色大成网站www久久九九| 国产三级三级在线观看| 久久99国产精品久久久久久久久| 亚洲精品不卡在线观看| 全黄性性激高免费视频| 99麻豆久久久国产精品免费| 亚洲图片在线视频| 在线观看国产精品淫| 色8久久久久| 91亚洲精品国产| 久久综合中文字幕| 中国a一片一级一片| 欧美成人合集magnet| 久久精品66| 国产精品视频黄色| 亚洲另类一区二区| 神宫寺奈绪一区二区三区| 奇米影视亚洲狠狠色| 91一区在线| 美女露出粉嫩尿囗让男人桶| 狠狠色狠狠色综合日日五| 福利视频在线播放| 3d蒂法精品啪啪一区二区免费| 在线看片一区| 午夜影院黄色片| 日韩精品在线一区| 欧美xxx性| 免费极品av一视觉盛宴| 久久无码av三级| 国产福利小视频| 日本成人在线视频网址| 国产精品精品| 好吊日免费视频| 日韩一级片在线播放| 日韩欧美另类一区二区| 天堂av免费看| 91香蕉视频污| 国产女无套免费视频| 日本精品视频在线观看| 婷婷丁香综合| 性高潮久久久久久久| 日韩欧美一区二区视频| 成人激情视屏| 中国丰满人妻videoshd| 亚洲女人小视频在线观看| 三级视频在线| 福利精品视频|