精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

免费在线国产视频| 一本一道精品欧美中文字幕| 麻豆一区一区三区四区| 欧美日韩亚洲激情| 先锋影音一区二区三区| 国产成人三级在线播放| 国产亚洲精品bv在线观看| 亚洲偷欧美偷国内偷| 99九九99九九九99九他书对| 欧美寡妇性猛交xxx免费| 久久综合九色综合欧美98| 91精品国产综合久久香蕉| 国产精选第一页| 91亚洲国产| 亚洲国产古装精品网站| 亚洲精品www.| 日本在线影院| 亚洲六月丁香色婷婷综合久久| 久久国产一区| 国产成人精品无码高潮| 久热国产精品| 欧美精品videos| 国产wwwwxxxx| 久久不见久久见中文字幕免费| 日韩视频在线一区二区| 激情视频综合网| 波多野在线观看| 亚洲色图欧美偷拍| 日本一区二区视频| 手机看片国产1024| 国产一区二区三区久久悠悠色av| 国产成人精品免高潮费视频| 国产精品第二十页| 一区二区三区在线| 色婷婷综合久久久久| 三上悠亚ssⅰn939无码播放| 97久久综合精品久久久综合| 91精品国产高清一区二区三区蜜臀| 99精品免费在线观看| 电影在线观看一区| 亚洲综合色成人| 国产又粗又硬又长| 欧美激情二区| 国产精品美女久久福利网站| 午夜欧美性电影| 久久久久久青草| 26uuuu精品一区二区| 精品高清视频| 五月色婷婷综合| 成人一区二区三区视频| 91gao视频| 国产xxxxxx| 国产一区二区电影| 亚洲自拍欧美另类| 国产熟女一区二区三区五月婷| 久久爱另类一区二区小说| 国产精品久久久久99| 在线免费观看国产精品| 青青草97国产精品免费观看| 国产精品99蜜臀久久不卡二区| 国产污视频网站| 日一区二区三区| 国产精品高潮在线| 亚洲在线观看av| 九九国产精品视频| 3d动漫啪啪精品一区二区免费 | 国产精品久久久久久久小唯西川 | 国产精品亚洲一区二区三区在线| 91精品久久久久久久久久| 91av久久久| 国产乱子伦一区二区三区国色天香| 成人在线视频网| a天堂视频在线| av中文一区二区三区| 免费精品视频一区| 香蕉视频网站在线观看| 亚洲男人天堂av网| 男女私大尺度视频| 欧美日韩五码| 欧美一级精品大片| 国产真实乱人偷精品| 国产亚洲欧美日韩在线观看一区二区 | 日av在线播放| 国产精品你懂的在线欣赏| 免费成人深夜夜行网站视频| av漫画网站在线观看| 欧美性猛交xxxx免费看漫画| 国产九九在线观看| 88久久精品| 亚洲欧美制服另类日韩| 欧美性生给视频| 99精品国产在热久久| 国产精品极品美女在线观看免费| 国产视频第二页| 99久久国产免费看| 亚洲精品一区二区三区av| 男女在线视频| 欧美午夜精品一区| caopor在线| 欧美精品一区二区三区中文字幕| 欧美成人精品xxx| 欧美一区二区三区网站| 国产乱码精品一区二区三 | 久久精品aⅴ无码中文字字幕重口| 亚洲免费福利一区| 精品中文字幕在线2019| 欧美成人精品网站| 不卡视频一二三四| 神马午夜伦理影院| 免费观看成人性生生活片| 欧美成人a在线| 欧美成人短视频| 国产精品美女久久久浪潮软件| 成人写真福利网| 日本v片在线免费观看| 亚洲一区二区三区四区在线| 手机免费av片| 激情五月色综合国产精品| 久久久亚洲影院| 国产精品自拍电影| 中文乱码免费一区二区| 精品国产成人av在线免| 久久91在线| 色综合久久悠悠| 国产精品一区二区免费视频| 欧美激情中文字幕一区二区| 成年人视频观看| 国产精品毛片av| 色综合老司机第九色激情| 国产又粗又长又大视频| 日本一区二区视频在线观看| 国产1区2区在线| 日韩高清成人在线| 韩国精品久久久999| 国内精品偷拍视频| 亚洲色图20p| 日韩av自拍偷拍| 999久久久精品国产| 国产精品网站入口| 午夜激情视频在线| 欧美日韩高清不卡| 少妇视频一区二区| 久久精品国产99| 亚洲人体一区| 青娱乐极品盛宴一区二区| 一区二区三区视频观看| 中文字幕一区二区人妻视频| 国产嫩草影院久久久久| 日日噜噜夜夜狠狠| 久久人体视频| 成人免费激情视频| free性欧美hd另类精品| 91精品国产一区二区三区| 来吧亚洲综合网| 久久66热偷产精品| 在线观看17c| 亚洲一区 二区| 久久久久五月天| 五月天婷婷视频| 一本到不卡免费一区二区| 亚洲av无码成人精品国产| 久久久久99| 天堂√在线观看一区二区| 岛国一区二区| 欧美老女人在线视频| 粉嫩av一区二区夜夜嗨| 激情av一区二区| 人妻少妇无码精品视频区| 美女视频网站久久| www.激情网| 婷婷五月色综合香五月| 国产精品黄页免费高清在线观看| 国产写真视频在线观看| 精品91自产拍在线观看一区| 黄色在线观看国产| 国产精品日韩成人| 国产伦精品一区二区三区妓女下载 | 不卡视频在线播放| 欧美日韩中文在线观看| 手机毛片在线观看| 国产电影精品久久禁18| 日本毛片在线免费观看| 日韩大片在线观看| yellow视频在线观看一区二区| 亚洲优女在线| 插插插亚洲综合网| 偷拍精品一区二区三区| 欧美日韩黄色影视| 日本学生初尝黑人巨免费视频| 久久精品男人的天堂| 奇米777在线视频| 免费永久网站黄欧美| 中文字幕一区二区三区精彩视频 | 91国拍精品国产粉嫩亚洲一区| 美女福利精品视频| 精品av中文字幕在线毛片| 91精品国产综合久久香蕉麻豆| 亚洲精品午夜国产va久久成人| 国产精品伦理在线| 三级电影在线看| 国产一区欧美一区| 熟妇人妻无乱码中文字幕真矢织江| 欧美人与禽猛交乱配视频| 日本黄网免费一区二区精品| 91免费精品国偷自产在线在线| 国产精品久久综合av爱欲tv| av手机在线观看| 久久国产加勒比精品无码| 成年人在线免费观看| 亚洲国产一区自拍| 国产伦理吴梦梦伦理| 欧美系列亚洲系列| www.com国产| 亚洲国产成人精品视频| 亚洲欧美精品aaaaaa片| 中文字幕精品—区二区四季| 精品夜夜澡人妻无码av| 国产成人午夜视频| 亚洲第一区第二区第三区| 日韩av一二三| av免费在线播放网站| 日韩午夜高潮| 欧美一级片免费播放| 国产综合精品| 精品免费久久久久久久| 亚洲澳门在线| 在线观看欧美亚洲| 青青草国产免费一区二区下载| 久久综合九色99| 欧美sss在线视频| 国产精品一区二区a| 9999精品| 3d精品h动漫啪啪一区二区| 9999精品视频| 亚洲永久在线观看| 警花av一区二区三区| 91免费看国产| 精品中文在线| 成人av片网址| 国产精品1luya在线播放| 懂色一区二区三区av片| 亚洲精品在线播放| 高清国产在线一区| 成人自拍在线| 九色91国产| 最近国产精品视频| 青青草国产精品| 成人3d动漫在线观看| 亚洲人成77777| 欧美激情欧美| av动漫在线免费观看| 亚洲天堂偷拍| 国产精品丝袜久久久久久消防器材| 国产视频一区欧美| 久久精品网站视频| 美腿丝袜亚洲综合| 亚洲第一色av| a美女胸又www黄视频久久| 粉嫩av蜜桃av蜜臀av| 亚洲国产岛国毛片在线| 天天做夜夜爱爱爱| 亚洲最大色网站| 日韩黄色在线播放| 欧美日韩一区二区三区四区| 97在线视频人妻无码| 精品国产免费人成在线观看| 五月天福利视频| 自拍偷拍免费精品| 亚洲七七久久综合桃花剧情介绍| 久久男人的天堂| 激情开心成人网| 成人国产精品色哟哟| 国产精品qvod| 无遮挡亚洲一区| 欧美极品一区二区三区| 日本毛片在线免费观看| 久久av中文字幕片| 动漫美女无遮挡免费| 国产三级精品三级在线专区| 久久国产美女视频| 动漫精品一区二区| 国产又粗又猛视频免费| 日韩精品综合一本久道在线视频| 欧美挠脚心网站| 欧美成人第一页| 日韩在线短视频| 91精品国产一区二区三区动漫| 老司机成人在线| 中文字幕在线亚洲精品| 99香蕉国产精品偷在线观看 | 国产精品久久久久久久久久白浆| 视频在线观看成人| 激情久久一区| 一级做a免费视频| 99re热这里只有精品免费视频| 黄色香蕉视频在线观看| 欧美视频13p| 国产国语亲子伦亲子| 亚洲一区二区久久| heyzo一区| 亚洲自拍欧美色图| 色综合天天爱| 精品人妻一区二区三区四区在线 | 黄瓜视频污在线观看| 亚洲精选在线视频| 一区二区视频网站| 国产午夜精品久久久| 黄页网站在线| 成人黄色在线免费| 精品freesex老太交| 婷婷无套内射影院| 国产福利一区二区三区视频在线| 黄色av免费播放| 一本久久a久久免费精品不卡| 日本美女一级视频| 69xxxx国产| 一区二区欧美视频| 中文字幕1区2区| 欧美韩国日本一区| 天堂中文字幕在线观看| 欧美成人伊人久久综合网| 男人在线资源站| 国产精品一区二区三区成人| 免费av一区| www插插插无码视频网站| 国产精品资源在线| 三上悠亚在线观看视频| 在线视频国内一区二区| 青青青草原在线| 91a在线视频| 久久资源综合| 蜜臀av无码一区二区三区| 国产成人一级电影| tube国产麻豆| 欧美一级片在线看| 成人日韩欧美| 亚洲iv一区二区三区| 亚洲综合专区| 91porn在线| 亚洲国产中文字幕| 成人午夜福利视频| 欧美激情欧美激情| 一区二区精彩视频| 国产91在线亚洲| 成人免费观看av| 日韩av在线天堂| 日韩av在线网址| 正在播放日韩精品| 日本在线视频一区| 蜜桃久久精品一区二区| 蜜桃av.com| 日韩精品资源二区在线| 欧美hdxxxxx| αv一区二区三区| 亚洲电影成人| wwwwxxxx国产| 欧美日韩精品二区第二页| 18videosex性欧美麻豆| 国产精品久久一区二区三区| 国产一区导航| 丁香花五月婷婷| 51精品久久久久久久蜜臀| 尤物在线网址| 精品久久久三级| 日韩av二区在线播放| 久久国产波多野结衣| 精品久久久久久久久久久久包黑料 | 国产一区二中文字幕在线看| 中文一区一区三区免费在线观看| 最新版天堂资源在线| 欧美性生交xxxxx久久久| h视频在线观看免费| 91精品国产一区二区三区动漫| 亚洲一区二区三区四区五区午夜| 亚洲成人黄色av| 91精品国产91久久久久久一区二区| 538视频在线| 亚洲日本精品| a在线播放不卡| 伊人亚洲综合网| 国模吧一区二区三区| 成人毛片免费看| 亚洲av无码一区东京热久久| 在线精品观看国产| 亚洲www色| 欧美一二三四五区| 国产精品乡下勾搭老头1| 国产成人无码av| 欧美精品做受xxx性少妇| 国产亚洲一卡2卡3卡4卡新区| 妖精视频在线观看| 在线观看免费一区| 丁香影院在线| 亚洲精品视频一区二区三区| av成人免费在线观看| 国产又大又黄的视频| 国产成人精品久久二区二区91| 伊人成人在线| 国产尤物在线播放| 亚洲视频在线看|