日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 Vue 正文

element?Dropdown組件意想不到的坑_vue.js

作者:HED ? 更新時間: 2022-04-06 Vue

去年做的兩個web項目,都用到了elementUI,自認為已經比較熟悉了,尤其是其中一些常用的組件,比如說今天的主角——Dropdown。

所以,今年項目中,如果再用到的話,應該不會踩坑了。畢竟,對它的坑,已經比較了解了。它常見的坑主要有以下兩個:

1、el-dropdown下拉el-dropdown-item添加點擊事件click沒有反應

踩坑寫法:

<el-dropdown-item @click="remoToken">退出</el-dropdown-item>

避坑寫法:

<el-dropdown-item @click.native="remoToken">退出</el-dropdown-item>

2、el-table組件中使用Dropdown,無法顯示下拉框

踩坑寫法:

<el-table-column>
? <el-dropdown><el-dropdown>
<el-table-column>

避坑寫法

<el-table-column>
? <template slot-scope="scope">
? ? <el-dropdown><el-dropdown> ?
? </template>
<el-table-column>

但是,昨天,在使用Dropdown組件時,還是踩了一個意想不到的坑!
事情是這樣的。

也是在el-table組件中使用Dropdown,已經采用了避坑寫法,大概寫法如下:

<el-table-column>
? <template slot-scope="scope">
? ? <el-dropdown v-if="status === 1">
? ? ?<a>{{activeSelect}}<i class="el-icon-arrow-down el-icon--right"></a>
? ? ?<el-dropdown-menu slot="dropdown">
? ? ? ?<el-dropdown-item command="a">進入面試</el-dropdown-item>?
? ? ? ?<el-dropdown-item command="b">入職</el-dropdown-item>
? ? ?</el-dropdown-menu>
? ? <el-dropdown> ?
? ? <el-dropdown v-if="status === 2">
? ? ?<a>{{activeSelect}}<i class="el-icon-arrow-down el-icon--right"></a>
? ? ?<el-dropdown-menu slot="dropdown">
? ? ? ?<el-dropdown-item command="b">入職</el-dropdown-item>
? ? ?</el-dropdown-menu>
? ? <el-dropdown>?
? </template>
<el-table-column>

可是,不管怎么點擊,Dropdown下拉框就是不顯示。

問題到底出現在哪?百思百搜不得其解!

后來沒辦法,就把自己的代碼注釋掉,換上了一組官方文檔中的示例代碼。突然,下拉框出來了!這是為什么?

仔細對比了一下,代碼沒什么區別,除了原來的代碼有兩組Dropdown,現在的只有一組Dropdown,難道問題出現在這里。

這時,腦袋中突然浮現出一句話:v-if 、v-else-if 和v-else 最好搭配使用,形成完整的邏輯判斷。

果斷把代碼改成如下:

<el-table-column>
? <template slot-scope="scope">
? ? <el-dropdown v-if="status === 1">
? ? <el-dropdown> ?
? ? <el-dropdown v-else-if="status === 2">
? ? <el-dropdown>?
? </template>
<el-table-column>

一試,下拉框正常出來了!
問題還真出現在這,以前也經常多個v-if 一起用,也沒問題,為什么到這個場景中就不行(求大神指教)。

原文鏈接:https://juejin.cn/post/7055971409381556261

欄目分類
最近更新