VUE的指令

来源:https://www.cnblogs.com/xiaoqi520/archive/2018/11/21/9994121.html
-Advertisement-
Play Games

vue所有的指令都是以 " v-" 開頭。 v-html:類似於 js中的innerHTML 。可以解析模板中的標簽。 v-text:類似於 js中的innerText。將模板中的數據以字元串的形式輸出。不會解析模板中的標簽。等價於 {{ }} :防止刷新時{{ }}出現在頁面上 v-show:通過 ...


vue所有的指令都是以 " v-" 開頭。

v-html:類似於 js中的innerHTML 。可以解析模板中的標簽。

v-text:類似於 js中的innerText。將模板中的數據以字元串的形式輸出。不會解析模板中的標簽。等價於 {{ }} :防止刷新時{{ }}出現在頁面上

v-show:通過控制cssdisplay來控制元素的實現和隱藏如果是頻繁切換則推薦用此方法。節約性能。

v-if:當屬性值為true時,則顯示當前的元素,為false,那麼顯示v-false的元素。如果是偶爾切換,甚至不切換,則建議使用這個。減緩首次加在壓力,提高性能。

v-else-if:配合著 v-if 使用,當條件不成立時,執行這步

v-else :當以上條件都不成立時,執行這一步。

 1 <!DOCTYPE html>
 2 <html lang="en">    
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 </head>
 7 <body>
 8 <div id="app">
 9     <div v-if="mag<0">小於0</div>
10     <div v-else-if="mag<10">0-9</div>
11     <div v-else>大於10</div>
12 </div>
13 </body>
14 <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
15 <script>
16     var vm=new Vue({
17         el:"#app",
18         data:{
19             mag:15
20         },
21     })
22 </script>
23 </html>

v-once:只綁定一次,當數據再次發生變化,也不會導致頁面刷新,寫在不想刷新的標簽上。

v-bind:單向數據綁定

1   <!--完整寫法-->
2     <a v-bind:href="url">1111</a>
3     <!--簡寫-->
4     <a :href="url">2222</a>

一般用於class的獲取

1 <ul class="box" v-bind:class="{‘textColor‘:isColor, ‘textSize‘:isSize}">
2     <li>學習Vue</li>
3     <li>學習Node</li>
4     <li>學習React</li>
5 </ul>
1 var vm= new Vue({
2     el:‘.box‘,
3     data:{
4         isColor:true,
5         isSize:true
6     }
7 })

v-on: 綁定事件。

1    <!--完整寫法-->
2     <button v-on:click="doThis"></button>
3      <!--簡寫-->
4     <button @click="doThis"></button>

監聽DOM事件,函數需要定義在methods中,不能和data中的內容重名,不能使用箭頭函數 

  • 如果在綁定時,fn不帶(),那麼函數會預設接收一個事件對象emouseEvent ,如果綁定時帶有小括弧,那麼預設接收事件對象,
  • 既需要事件對象,又需要參數,需要在綁定的小括弧中加一個$event,後面才是真正的實參

v=for:迴圈

  迴圈數組 

1     <!--html-->
2     <div v-for="item in arr">{{item}}</div>
1     var vm=new Vue({
2         el:"#app",
3         data:{
4             arr:[1,2,4,574,45,448]
5         },
6     })

效果如下:item 代表每一項

 迴圈字元串

1 <div v-for="item in str">{{item}}</div>
1     var vm=new Vue({
2         el:"#app",
3         data:{
4             str:"fdhsde"
5         },
6     })

效果如下 : item 代表著每一個字元

迴圈對象

 <div v-for="(item,key,index) in obj">{{item}}--{{key}}--{{index}}</div>
 1     var vm=new Vue({
 2         el:"#app",
 3         data:{
 4             obj:{
 5                 name:"qi",
 6                 age:"22",
 7             }
 8 
 9         },
10     })

效果如下: 第一個參數是 屬性值  ,第二個參數是 屬性名,第三個參數是索引。

迴圈數字

1     <div v-for="item in 6">{{item}}</div>

效果如下 :

v-cloak :用於元素載入數據比較多時,vue解析時間比較長,為了防止{{}}出現,給該元素加上v-cloak屬性,直到vue中把DOM數據插入到真實DOM中時,讓當前的元素顯示;

1 <div class="#app" v-cloak>
2     <p>{{value.name}}</p>
3 </div>
1 [v-cloak] {
2     display: none;
3 }

但是有的時候會不起作用,可能的原因有二:

  1、v-cloak的display屬性被層級更高的給覆蓋掉了,所以要提高層級

1 [v-cloak] {
2     display: none !important;
3 }

  2、樣式放在了@import引入的css文件中

    v-cloak的這個樣式放在@import 引入的css文件中不起作用,可以放在link引入的css文件里或者內聯樣式中

v-model:只用於表單元素忽略了value。checkbox selected,將數據綁定的視圖上,視圖修改會影響數據的變化(雙向數據綁定) 

  • 單選框中使用v-model :會將都綁定val的劃分成一組,只能選擇其中一個
  • 在覆選框中,如果只有一個,v-model 會將值預設轉換成布爾類型的值
  • 如果v-model 在覆選框中同時綁定一個值,那麼會把這幾個進行分組,把選中的值,同一放進數組中
  • 如果多個input框同時綁定一個相同的v-model,通過是否在數組中進行選中或者不選擇,各自來控制自己的狀態
  • 用於下拉框那麼select上v-model綁定的值:跟option中的value屬性有關 ,那麼如果沒有value屬性,那麼會取option標簽中的內容

 


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

-Advertisement-
Play Games
更多相關文章
  • 總體思路是在table外部加個div,修改div的innerHtml實現改變tr順序的效果 具體思路是 獲取當前要移動tr行的rowIndex,在table中刪除掉,然後迴圈table的rows,到了目標行再直接加進去,最後把整體的html賦值給div完成效果 js代碼如下 測試html代碼如下 ...
  • 為table設置最小寬度,當超過最小寬度的時候會auto。直接設置為width:auto , 並不能起到這個效果。 ...
  • 今天項目比較催的比較著急,瀏覽器總是崩潰,後來報了一個Uncaught RangeError: Invalid string length(字元串長度無效) 的錯誤。 在ajax請求後得到的json數據,遍歷的時候chrome控制台報這個錯誤:Uncaught RangeError: Invalid ...
  • rem是指相對於根元素(html)的字體大小的單位,他是一個相對單位,我們現在有很多人用的都是px,但px是一個絕對單位,遇到解析度不同的設備,做出的頁面可能會亂,這就給我們造成了很大的影響,而且後期的修複也很費時間,所以rem是一個很不錯的適配方法。 下麵直接進入例子: 在這裡設置html的fon ...
  • 因為圖片是動態創建的,在插件開始初始化時,文檔流中沒用圖片,故沒有創建相應寬度。通過調整js載入順序,問題還是沒有解決。 最後找到swiper插件 api 有屬性是可以根據內容變動,自動初始化插件的,添加observer:true後問題解決! var mySwiper = new Swiper (' ...
  • 表達式全集 常用正則表達式 ...
  • Button組件 button.vue Radio組件 radio.vue 解析: (1)組件的html結構 整個組件是一個外層label嵌套兩個span。label放在最外面的作用是擴大滑鼠點擊範圍,點擊文字或者input都能觸發響應。 第一個 表示圓形按鈕,裡面的span就是模擬的圓圈,inpu ...
  • 前端工程師,也叫Web前端開發工程師。他是隨著web發展,細分出來的行業。Web前端開發技術主要包括三個要素:HTML、CSS和JavaScript!它要求前端開發工程師不僅要掌握基本的Web前端開發技術,網站性能優化、SEO和伺服器端的基礎知識,而且要學會運用各種工具進行輔助開發以及理論層面的知識 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...