Vue.js中定義元件範本的幾種方法介紹
Vue.js 使用了基於 HTML 的模板語法,允許開發者宣告式地將 DOM 綁定至底層 Vue 實例的資料。所有 Vue.js 的範本都是合法的 HTML ,所以能被遵循規範的瀏覽器和 HTML 解析器解析。
在Vue中定義元件模板有很多選擇。在我看來,至少有七種不同的方式:
字串
#模板文字
#X-Templates
內聯
#渲染功能
-
JSX
單頁元件
在本文中,我們將逐一介紹每種方法的範例,並討論其優缺點,以便您了解在任何特定情況下使用哪種方法最好。
1、字串
預設情況下,範本將定義為JS檔案中的字串。我想我們都同意字串中的模板是非常難以理解的。除了廣泛的瀏覽器支援之外,這個方法沒有什麼特別之處。
Vue.component('my-checkbox', { template: `<div class="checkbox-wrapper" @click="check"> <div :class="{ checkbox: true, checked: checked }"> </div><div class="title">{{ title }}</div></div>`, data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } } });
2、模板文字
#ES6模板字面量(“backticks”)允許您跨多行定義模板,這是在常規Javascript字串中無法做到的。雖然為了安全起見,您可能仍然應該轉換為ES5,但現在許多新瀏覽器都支援這些命令,並且更容易閱讀。
不過,這種方法並不完美;我發現大多數ide在語法高亮、製表符、換行等方面仍然讓您感到痛苦。
Vue.component('my-checkbox', { template: ` < div class = "checkbox-wrapper"@click = "check" > <div: class = "{ checkbox: true, checked: checked }" ></div> <div class="title">{{ title }}</div ></div>`, data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } } });/
3、X-Templates
使用此方法,您的範本將在index.html檔案中的腳本標記中定義。腳本標記由文字/x-template標記,並由元件定義中的id引用。
我喜歡這種方法,它允許您用正確的HTML標記編寫HTML,但缺點是它將模板與元件定義的其餘部分分開。
Vue.component('my-checkbox', { template: '#checkbox-template', data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } } });
<script type="text/x-template" id="checkbox-template"> <div class="checkbox-wrapper" @click="check"> <div :class="{ checkbox: true, checked: checked }"></div> <div class="title">{{ title }}</div> </div> </script>
4、內嵌模板
#透過將inline-template屬性,您可以向Vue表明內部內容是其模板,而不是將其視為分散式內容。
它的缺點與x-templates相同,但一個優點是內容在HTML範本中的正確位置,因此可以在頁面載入時呈現,而不是等到Javascript執行時。
Vue.component('my-checkbox', { data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } } });
<my-checkbox inline-template> <div class="checkbox-wrapper" @click="check"> <div :class="{ checkbox: true, checked: checked }"></div> <div class="title">{{ title }}</div> </div> </my-checkbox>
5、渲染功能
呈現函數要求您將模板定義為Javascript物件。它們顯然是模板選項中最冗長和抽象的。
但是,這樣做的好處是模板更接近編譯器,並且允許您存取完整的Javascript功能,而不是指令提供的子集。
Vue.component('my-checkbox', { data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } }, render(createElement) { return createElement( 'div', { attrs: { 'class': 'checkbox-wrapper' }, on: { click: this.check } }, [ createElement( 'div', { 'class': { checkbox: true, checked: this.checked } } ), createElement( 'div', { attrs: { 'class': 'title' } }, [ this.title ] ) ] ); } });
6、JSX
Vue中最有爭議的範本選項是JSX。有些開發人員認為JSX醜陋、不直觀,是對Vue精神的背叛。
JSX要求您先轉換,因為瀏覽器無法讀取它。但是,如果需要使用呈現函數,JSX肯定是定義模板的一種不那麼抽象的方法。
Vue.component('my-checkbox', { data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } }, render() { return <div class="checkbox-wrapper" onClick={ this.check }> <div class={{ checkbox: true, checked: this.checked }}></div> <div class="title">{ this.title }</div> </div> } });
7、單一檔案元件
#只要您對在設定中使用建置工具感到滿意,單一檔案元件就是範本選項之王。它們帶來了兩方面的好處:允許您在編寫標記的同時將所有元件定義保存在一個檔案中。
它們需要換位,而且有些ide不支援這種檔案類型的語法高亮顯示,但在其他方面很難打敗它們。
<template> <div class="checkbox-wrapper" @click="check"> <div :class="{ checkbox: true, checked: checked }"></div> <div class="title">{{ title }}</div> </div> </template> <script> export default { data() { return { checked: false, title: 'Check me' } }, methods: { check() { this.checked = !this.checked; } } } </script>
您可能會爭辯說,有更多的模板定義的可能性,因為您可以使用模板預處理程序,例如Pug與SFCs!
哪個最好?
當然沒有一種完美的方式,每一種都應該根據你的用例來判斷。我認為最好的開發人員會意識到所有可能性,並將每個開發人員作為他們的Vue.js工具帶中的工具!
英文原文網址:https://vuejsdevelopers.com/2017/03/24/vue-js-component-templates/
相關推薦:
更多程式相關知識,請造訪:程式設計入門! !
以上是Vue.js中定義元件範本的幾種方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

使用vue框架開發前端專案時,我們部署的時候都會部署多套環境,往往開發、測試以及線上環境呼叫的介面網域都是不一樣的。如何能做到區分呢?那就是使用環境變數和模式。

Ace 是一個用 JavaScript 寫的可嵌入程式碼編輯器。它與 Sublime、Vim 和 TextMate 等原生編輯器的功能和效能相符。它可以很容易地嵌入到任何網頁和 JavaScript 應用程式中。 Ace 被維護為Cloud9 IDE的主要編輯器 ,並且是 Mozilla Skywriter (Bespin) 專案的繼承者。

組件化和模組化的區別:模組化是從程式碼邏輯的角度進行劃分的;方便程式碼分層開發,確保每個每個功能模組的職能一致。元件化是從UI介面的角度進行規劃;前端的元件化,方便UI元件的重複使用。

在當今前端開發中,Vue.js 已經成為了一個非常流行的框架。隨著 Vue.js 的不斷發展,單元測試變得越來越重要。今天,我們將探討如何在 Vue.js 3 中編寫單元測試,並提供一些最佳實踐和常見的問題及解決方案。

在我們使用高德地圖的時候,官方給我們推薦了很多案例,demo,但是這些案例都是使用原生方法接入,並沒有提供vue或者react 的demo,vue2的接入網上也很多人都有寫過,以下這篇文章就來看看vue3怎麼使用常用的高德地圖api,希望對大家有幫助!

查詢目前vue版本的兩種方法:1、在cmd控制台內,執行「npm list vue」指令查詢版本,輸出結果就是vue的版本號資訊;2、在專案中找到並開啟package.json文件,查找「dependencies」項目即可看到vue的版本資訊。

在Vue.js中,開發人員可以使用兩種不同的語法來建立使用者介面:JSX語法和範本語法。這兩種文法各有優劣,以下就來探討它們的差異和優劣勢。

在實際開發專案過程中有時候需要上傳比較大的文件,然後呢,上傳的時候相對來說就會慢一些,so,後台可能會要求前端進行文件切片上傳,很簡單哈,就是把比如說1個G的檔案流切割成若干個小的檔案流,然後分別請求介面傳遞這個小的檔案流。
