說一下最近遇到的一個bug,以及解決方案,然後由此說一下這三者的區別。
data:image/s3,"s3://crabby-images/be141/be14110f9c719f4480b99c0003901ad1a895ddad" alt="v-html 、v-text({{}}) 、v-model的區別"
在資料裡面這樣顯示
data:image/s3,"s3://crabby-images/02069/0206968e5c57c8dae1792110e90f716762f802aa" alt="v-html 、v-text({{}}) 、v-model的區別"
當我用{{}}直接將這個欄位顯示出來時
data:image/s3,"s3://crabby-images/1e47f/1e47f5bc8cc20fc513378e763a745fe5ee44533a" alt="v-html 、v-text({{}}) 、v-model的區別"
頁面顯示這種情況
data:image/s3,"s3://crabby-images/c359b/c359bbcc18cfb97cd750c00126dbff276cce6b70" alt="v-html 、v-text({{}}) 、v-model的區別"
即有的icon能解析但是有的卻不能解析 這個時候我們用v-html
data:image/s3,"s3://crabby-images/a7b8b/a7b8bfb45ffd517988f60f7538c3cc65f3867545" alt="v-html 、v-text({{}}) 、v-model的區別"
這個時候頁面
data:image/s3,"s3://crabby-images/aa10a/aa10a3e3b2358668e62d0a75930da556e71452f3" alt="v-html 、v-text({{}}) 、v-model的區別"
由此探討下v-html v-text({{}}) v-model的區別
- v-html
v-html用於輸出html,它與v-text區別在於v-text輸出的是純文字,瀏覽器不會對其再進行html解析,但v-html會將其當html標籤解析後輸出。
- v-text
v-text是用於操作純文字,它會替代顯示對應的資料物件上的值,當繫結的資料物件上的值發生改變,插值處的內容也隨之更新。注意:此處為單向繫結,資料物件上的值改變,插值會發生變化;但是當插值發生變化並不會影響資料物件的值。其中:v-text可以簡寫為{{}},並且支援邏輯運算。
- v-model
v-model通常用於表單元件的繫結,例如input ,select等。它與v-text的區別在於它實現的表單元件的雙向繫結(資料物件上的值改變,插值會發生變化;當插值發生變化時,資料物件的值也會改變。),如果用於表單控制元件以外標籤是沒有用的。