創建全局組件的三種方式

来源:https://www.cnblogs.com/duxiu-fang/archive/2019/08/08/11321636.html
-Advertisement-
Play Games

什麼是組件? 組件的出現,就是為了拆分Vue實例的代碼量的,能夠讓我們以不同的組件,來劃分不同的功能模塊,將來我們需要什麼樣的功能,就可以去調用對應的組件就可以了。 組件化和模塊化的區別 模塊化:是從代碼邏輯的角度進行劃分的,方便代碼分層開發,保證每個模塊功能的職能單一。例如:NodeJS 組件化: ...


什麼是組件?

  組件的出現,就是為了拆分Vue實例的代碼量的,能夠讓我們以不同的組件,來劃分不同的功能模塊,將來我們需要什麼樣的功能,就可以去調用對應的組件就可以了。

組件化和模塊化的區別

  • 模塊化:是從代碼邏輯的角度進行劃分的,方便代碼分層開發,保證每個模塊功能的職能單一。例如:NodeJS
  • 組件化:是從UI界面的角度進行劃分的,前端的組件化,方便UI組件的重用

方式一

  使用 Vue.extend 配合 Vue.component  來進行創建全局組件

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8" />
    <title>獨秀不愛秀</title>
</head>
<body>
    <div id="app">
        <!-- 如果要使用組件,直接把組件的名稱,以 HTML 標簽的形式,引入到頁面中 -->
        <mycom1></mycom1>
    </div>

    <script src="./lib/vue-2.4.0.js"></script>

    <script type="text/javascript">
        // 1.1 使用 Vue.extend 來創建全局的 Vue 組件
        const com1 = Vue.extend({
            template: '<h3>這是使用 Vue.extent 創建的組件</h3>'// 通過 template 屬性,指定組件要展示的 HTML 結構
        });
        // 1.2 使用 Vue.component('組件的名稱', 創建出來的組件模板對象)
        // Vue.component('myCom1', com1);
        // 如果使用 Vue.component 定義全局組件的時候,組件名使用了 駝峰命名,則
        // 在引用的時候,需要把大寫字元改為小寫字元,同時,兩個單詞連接使用 -
        Vue.component('mycom1', com1);

        const vm = new Vue({
            el: '#app',
            data: {},
            methods: {}
        });
    </script>
</body>
</html>

當然,方式一也可以直接將第一步驟省略,直接:

Vue.component('mycom1', Vue.extend({
        template: '<h3>這是使用 Vue.extend 創建的組件</h3>'
}));

方式二

  直接使用 Vue.component 創建組件(其實就是在方式一的基礎上更加省略而已)

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8" />
    <title>獨秀不愛秀</title>
</head>

<body>
    <div id="app">
        <mycom2></mycom2>
    </div>

    <script src="./lib/vue-2.4.0.js"></script>

    <script type="text/javascript">
        /**
        * 2. 直接使用 Vue.component 創建組件
        * @param1  {String}  組件的名稱
        * @param2  {Object}  組件模板對象
        */        
        Vue.component('mycom2', {
            // 註意:無論是哪種方式創建出來的組件,組件的模板中必須有且只有一個唯一的根元素
            template: '<div><h1>這是直接用 Vue.component 創建的組件</h1><span>123</span></div>'
        });

        const vm = new Vue({
            el: '#app',
            data: {},
            methods: {}
        });
    </script>
</body>

</html>

方式三

  在 方式二的基礎上將第二個參數中的HTML代碼結構,替換為一個 ID:

<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8" />
    <title>獨秀不愛秀</title>
</head>

<body>
    <div id="app">
        <mycom3></mycom3>
    </div>


    <!-- 在被控制的 #APP 外面,使用 template 元素定義組件的模板結構 -->
    <template id="tmpl">
        <div>
            <h1>這是通過 template 元素,在外部定義的組件結構,這個方式,有代碼的智能提示和高亮</h1>
            <h3>不錯,好用</h3>
        </div>
    </template>

    <script src="./lib/vue-2.4.0.js"></script>

    <script type="text/javascript">
        Vue.component('mycom3', {
            template: '#tmpl'
        });

        const vm = new Vue({
            el: '#app',
            data: {},
            methods: {}
        });
    </script>
</body>

</html>

 

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • jquerysessionjs插件使用介紹 by:授客 QQ:1033553122 JQuery-3.2.1.min.j 下載地址: https://gitee.com/ishouke/front_end_plugin/blob/master/jquery-3.2.1.min.js jqueryse ...
  • <form>元素: <input>元素: 常用屬性: type 文本框類型 name 指定了name的欄位才會被提交(不能用id代替name屬性) placeholder 占位符 value 輸入框中的文本 autofocus 自動聚焦 disabled 禁用 readonly 只讀 require ...
  • 一開始,我使用的是Jquery框架中的$.("#input").readOnly,發現取出的值為undefined,不知道是不是jQuery中不支持獲取標簽屬性的函數, 然後就使用了原生的document.getElementById("input1").readOnly並且可以更改它的值以及取值, ...
  • 寫在前面:前面的內容記錄了JavaScript的一些基本概念,本次主要講解一下JS中常用的語句。 和大多數其他編程語言一樣,JS也主要包括:選擇、迴圈、錯誤檢測、函數等。JS的語句基本是由值、運算符、表達式、關鍵字和註釋構成,但並不是語句一定包含所有以上要素。 電腦程式一般是指能夠被電腦執行的一 ...
  • swiper一款非常好用的輪播插件,支持移動端和PC端,用過很多次了,這次簡單的總結一下。方便以後查找使用,說明一下,下麵的例子是基於swiper 4.0+版本的,如果你是其他的版本,請自行前往官網查看 至於為什麼使用swiper,而不是自己手寫,請看下麵官網的截圖: 開個玩笑,說白了,就是這個確實 ...
  • /** * 對於由簡單類型數據組成的對象為元素組成的數組進行去重操作 * @params {Array} 需要去重的對象數組 * @returns {Array} 去重後的對象數組 */ function distinct(sourceArray) { var resultArray = []; v ...
  • 上一篇講了字元串的解析過程,這一篇來講講標識符(IDENTIFIER)的解析。 先上知識點,標識符的掃描分為快解析和慢解析,一旦出現Ascii編碼大於127的字元或者轉義字元,會進入慢解析,略微影響性能,所以最好不要用中文、特殊字元來做變數名(不過現在代碼壓縮後基本不會有這種情況了)。 每一位Jav ...
  • HTML特殊轉義字元列表 最常用的字元實體Character Entities 顯示說明實體名稱實體編號 半方大的空白 &ensp; &#8194; 全方大的空白 &emsp; &#8195; 不斷行的空白格 &nbsp; &#160; < 小於 &lt; &#60; > 大於 &gt; &#62; ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...