vue 組件使用中的一些細節點

細節一

基礎例子


vue 組件使用中的一些細節點


運行結果:


vue 組件使用中的一些細節點


以上大家都懂,這邊就不多說,回到代碼裡,有時候我們需要 tbody 裡面每一行是一個子組件,那我們代碼可以怎麼寫呢?我們可以這樣寫,定義一個全局組件,如下:


vue 組件使用中的一些細節點


然後我們在 body 裡面可以這麼調用:


vue 組件使用中的一些細節點


運行結果:


vue 組件使用中的一些細節點


可以看到 row 是有打印出來了,但它實際上裡面沒有任務內容,那我們的問題出在哪呢?回到代碼我們發現我們在創建 vue 實例的時候沒有指定要掛載的點,所以我們通過 el 來指定 vue 接管的 Dom ,如下:


vue 組件使用中的一些細節點


運行結果:


vue 組件使用中的一些細節點


感覺上沒有問題,但真的是這樣嗎?我們通過檢查元素,查看DOM結構:


vue 組件使用中的一些細節點


大家可以看到出錯啦?正常的三個 tr 應該是在 tbody 裡面, 而現在跑到跟 tbody 同一層了,這是怎麼回事呢?

在H5的規範裡面,要求我們 table 裡面有 tbody, tbody 裡面必須得放 tr,而現在我們使用子組件裡面寫成 row, 所以我們的瀏覽器在解析的時候就會出問題。

那麼我們一旦遇到這種情況出現 bug 要怎麼解呢? 這時候我們可以藉助 vue 提供的 is 屬性來解決這個問題。很簡單, tbody 裡面只能寫 tr, 那我們就都寫 tr,可是實際上我們要顯示 tr 並不是就真的只顯示 tr 空的內容,我們需要顯示 row 組件的內容,那怎麼做?

我們可以在 tr 多一個屬性is 讓它等於 row, 如下:


vue 組件使用中的一些細節點


這段代碼的意思是:我要用一個組件,但是我不能直接寫這個組件,所以我們寫了一個 tr, 我們用 is 表示雖然我寫的是 tr, 但它表示是 row 組件,這樣能既能符合 H5 的規範又能顯示我們組件的內容 ,程序就不會有 bug 了。

運行結果:


vue 組件使用中的一些細節點


一切正常。

·同樣我們使用 ul, select 標籤的時候,也可以用這種方法。·

細節二

基礎例子


vue 組件使用中的一些細節點


我們定義了一個組件 row,裡面有段文本,如果我們想把這段文本單獨提取出來用變量表示 ,那麼你很有可能會這樣寫:


vue 組件使用中的一些細節點


看似完美,在打開瀏覽器運行你會發現,bug 正向你招手:


vue 組件使用中的一些細節點


主要意思是 data 是要一個函數,而不是一個對象,什麼情況,在根組件,也就是最外層 vue 的實例,我們通過對象定義是 ok 的,但是在非根組件的子組件這樣定義是不行滴。data 定義要求是一個函數,同時這個函數要求返回一個對象,如下:


vue 組件使用中的一些細節點


運行結果:


vue 組件使用中的一些細節點


這樣問題就解決啦。

之所以這麼定義,原因是一個子組件不像根組件只被調用一次,而是可以多次調用,那麼每一個子組件的數據我們不希望和其它的子組件產生衝突或者說每個子組件都應該有一個自己的數據域,通過函數返回一個對象就可以實現這個需求。

細節三

基礎例子


vue 組件使用中的一些細節點


運行,點擊彈出click,沒毛病。vue 不建議我們在代碼裡面操作 Dom, 但是在處理一些極其複雜的動畫效果,我們還真得操作 Dom, 那麼在 vue 中如何操作 Dom 呢? 我們可以通過 ref 引用的方式,如下:


vue 組件使用中的一些細節點


這時候我們有個需求,就是點擊div 的時候,把裡面的內容打印出來,我們可以通過引用獲取div節點,然後打印div 裡面的內容即可:


vue 組件使用中的一些細節點



vue 組件使用中的一些細節點


運行結果:


vue 組件使用中的一些細節點


對前端的技術,架構技術感興趣的同學關注我的頭條號,並在後臺私信發送關鍵字:“前端”即可獲取免費的架構師學習資料

知識體系已整理好,歡迎免費領取。還有面試視頻分享可以免費獲取。關注我,可以獲得沒有的架構經驗哦!!


分享到:


相關文章: