欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue?element修改el-select控件長(zhǎng)度style=“width:XXpx“不生效的解決

 更新時(shí)間:2023年07月18日 09:17:14   作者:Kyulin151020  
這篇文章主要介紹了vue?element修改el-select控件長(zhǎng)度style=“width:XXpx“不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

element修改el-select長(zhǎng)度style=“width:XXpx“不生效

問(wèn)題

想要修改一個(gè)代碼如下,里面的select的長(zhǎng)度,然后單純地通過(guò)設(shè)置style="width:200px"發(fā)現(xiàn)不生效,實(shí)際控件可觸控區(qū)域以及占據(jù)區(qū)域確實(shí)變長(zhǎng)了,但是視覺(jué)上沒(méi)有變化。

<template>
? ? <div class="formHeader">
? ? ? ? ? ? <div style="margin-left:20px">
? ? ? ? ? ? ? ? ? ? <span>選項(xiàng):</span>
? ? ? ? ? ? ? ? ? ? <el-select v-model="form.selectValue" placeholder="請(qǐng)選擇" style="width:200px">
? ? ? ? ? ? ? ? ? ? ? ? <el-option
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? v-for="item in selectOption"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? :key="item.value"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? :label="item.label"
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? :value="item.value">
? ? ? ? ? ? ? ? ? ? ? ? </el-option>
? ? ? ? ? ? ? ? ? ? </el-select>
? ? ? ? ? ? ?</div>
? ? </div>
</template>
.formHeader .el-input {
? ? border-color: #409EFF;
? ? width: 150px;
}

原因

Element-UI 的 el-select (el-cascader也是)使用的其實(shí)是 input 標(biāo)簽 , 而 input 標(biāo)簽在瀏覽器中存在一個(gè)默認(rèn)的寬度 , 大約是 100px (不同的瀏覽器表現(xiàn)不同) 。

而如上圖所示,我設(shè)置了el-input的寬度為150px,所以在底層,使用的input還是150px。

解決方法

設(shè)置如下樣式即可:

? ? .fromHeader .el-select .el-input {
? ? ? ? border-color: #409EFF;
? ? ? ? width: 200px;
? ? }

element ui的el-select框和選項(xiàng)框的寬度設(shè)置問(wèn)題

最終效果圖

有數(shù)據(jù)時(shí):

在這里插入圖片描述

無(wú)數(shù)據(jù)時(shí):

在這里插入圖片描述

常見(jiàn)情況-有數(shù)據(jù)時(shí)

代碼:

<el-select v-model="devType" style="width:100%">
	<el-option v-for="item in devTypes" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>

說(shuō)明:

控制選擇框的寬度,通過(guò)設(shè)置el-select的style即可??刂泣c(diǎn)擊選擇框后彈出的選項(xiàng)框的寬度,直接設(shè)置el-option的style也可以,但是注意可能需要寫上!important才生效。

問(wèn)題:

問(wèn)題來(lái)了,如果想設(shè)置el-option的最小寬度等于el-select怎么辦?實(shí)際操作發(fā)現(xiàn),若選項(xiàng)比較短通常自適應(yīng)的寬度小于選擇框?qū)挾?,效果如圖:

在這里插入圖片描述

但是刷新頁(yè)面后,再次點(diǎn)擊查看選項(xiàng),其自適應(yīng)的寬度又等于選擇框的寬度了,效果如圖:

在這里插入圖片描述

費(fèi)解,源碼看不太懂,沒(méi)看出是怎么觸發(fā)調(diào)整選項(xiàng)框?qū)挾鹊模谑侵挥腥藶楦深A(yù)。

思考:只需要獲取el-select的寬度,賦給el-option即可。

解決代碼如下:

<el-select v-model="devType" @focus="setMinWidth" style="width:100%">
	<el-option v-for="item in devTypes" :key="item.value" :label="item.label" :value="item.value" :style="{'min-width': minWidth + 2 + 'px'}"></el-option>
</el-select>
setMinWidth (val) {
    this.minWidth = val.srcElement.clientWidth
}

說(shuō)明:

1、給el-select添加focus事件,當(dāng)選擇框的 input 獲得焦點(diǎn)時(shí)觸發(fā),獲取當(dāng)前節(jié)點(diǎn)的寬度存為最小寬度。

2、給el-option綁定樣式min-width最小寬度即可。

注意:

因?yàn)椴煌x擇框下的el-option不會(huì)同時(shí)出現(xiàn),即便改變了同一界面的多個(gè)選項(xiàng)框?qū)挾纫矝](méi)關(guān)系。

常見(jiàn)情況-無(wú)數(shù)據(jù)時(shí)

還有一個(gè)問(wèn)題,對(duì)于出現(xiàn)“無(wú)數(shù)據(jù)”的選擇框時(shí),如圖

在這里插入圖片描述

給el-option綁定樣式是無(wú)效的,因?yàn)閑l-option根本不存在。

解決代碼如下:

<el-select v-model="devType" style="width:100%" @focus="setMinWidthEmpty">
    <el-option v-for="item in devTypes" :key="item.value" :label="item.label" :value="item.value"></el-option>
</el-select>
setMinWidthEmpty (val) {
    // 無(wú)數(shù)據(jù)的情況下,給請(qǐng)選擇提示設(shè)置最小寬度
    let domEmpty = document.getElementsByClassName('el-select-dropdown__empty')
    if (domEmpty.length > 0) {
		domEmpty[0].style['min-width'] = val.srcElement.clientWidth + 2 + 'px'
    }
}

說(shuō)明:

1、給el-select添加focus事件,當(dāng)選擇框的 input 獲得焦點(diǎn)時(shí)觸發(fā),獲取當(dāng)前節(jié)點(diǎn)的寬度存為最小寬度。

2、同時(shí)獲取el-select-dropdown__empty樣式的節(jié)點(diǎn),設(shè)置最小寬度。

注意:

1、getElementsByClassName不是getElementByClassName

2、放置當(dāng)前選擇框有數(shù)據(jù)時(shí)執(zhí)行該段報(bào)錯(cuò),必須判斷空節(jié)點(diǎn)的數(shù)量,存在再設(shè)置最小寬度。

3、若同時(shí)有多個(gè)el-select-dropdown__empty樣式的節(jié)點(diǎn),應(yīng)該遍歷設(shè)置最小寬度,但是我只設(shè)置第一個(gè)竟然都能生效,原因未知。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入了解Vue3組件傳值方式

    深入了解Vue3組件傳值方式

    學(xué)習(xí)過(guò)?vue2?的寶子們肯定知道,組件傳值是?vue?項(xiàng)目開(kāi)發(fā)過(guò)程中必不可少的功能場(chǎng)景,在?vue2?里面有很多傳值的方式。今天就來(lái)和大家講講Vue3的組件傳值方式,需要的可以參考一下
    2022-07-07
  • vue打包更新packge.json版本號(hào)的全過(guò)程

    vue打包更新packge.json版本號(hào)的全過(guò)程

    這篇文章主要介紹了vue打包更新packge.json版本號(hào)的全過(guò)程,文章通過(guò)圖文結(jié)合的方式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-08-08
  • Vue路由 重定向和別名的區(qū)別說(shuō)明

    Vue路由 重定向和別名的區(qū)別說(shuō)明

    這篇文章主要介紹了Vue路由 重定向和別名的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • Vue瀏覽器鏈接與接口參數(shù)實(shí)現(xiàn)加密過(guò)程詳解

    Vue瀏覽器鏈接與接口參數(shù)實(shí)現(xiàn)加密過(guò)程詳解

    這篇文章主要介紹了Vue瀏覽器鏈接與接口參數(shù)實(shí)現(xiàn)加密過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-12-12
  • vue js秒轉(zhuǎn)天數(shù)小時(shí)分鐘秒的實(shí)例代碼

    vue js秒轉(zhuǎn)天數(shù)小時(shí)分鐘秒的實(shí)例代碼

    這篇文章主要介紹了vue js秒轉(zhuǎn)天數(shù)小時(shí)分鐘秒的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-08-08
  • vant中的picker選擇器自定義選項(xiàng)內(nèi)容

    vant中的picker選擇器自定義選項(xiàng)內(nèi)容

    這篇文章主要介紹了vant中的picker選擇器自定義選項(xiàng)內(nèi)容,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 基于vue3?vue-cli4?線上部署及優(yōu)化的問(wèn)題

    基于vue3?vue-cli4?線上部署及優(yōu)化的問(wèn)題

    這篇文章主要介紹了基于vue3?vue-cli4?線上部署及優(yōu)化的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue項(xiàng)目中的.env文件加載方式

    vue項(xiàng)目中的.env文件加載方式

    在Vue項(xiàng)目中,通過(guò).env文件配置環(huán)境變量,支持不同環(huán)境下加載不同配置,Vite通過(guò)import.meta.env向應(yīng)用暴露環(huán)境變量,支持基本URL、開(kāi)發(fā)環(huán)境和生產(chǎn)環(huán)境識(shí)別等,.env文件可設(shè)置環(huán)境優(yōu)先級(jí),修改后需重啟生效,TypeScript可通過(guò)增加文件獲取智能提示
    2024-10-10
  • vue解決彈出蒙層滑動(dòng)穿透問(wèn)題的方法

    vue解決彈出蒙層滑動(dòng)穿透問(wèn)題的方法

    這篇文章主要介紹了vue解決彈出蒙層滑動(dòng)穿透問(wèn)題的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue實(shí)現(xiàn)未登錄訪問(wèn)其他頁(yè)面自動(dòng)跳轉(zhuǎn)登錄頁(yè)功能(實(shí)現(xiàn)步驟)

    vue實(shí)現(xiàn)未登錄訪問(wèn)其他頁(yè)面自動(dòng)跳轉(zhuǎn)登錄頁(yè)功能(實(shí)現(xiàn)步驟)

    這篇文章主要介紹了vue實(shí)現(xiàn)未登錄下訪問(wèn)其他頁(yè)面自動(dòng)跳轉(zhuǎn)登錄頁(yè),本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07

最新評(píng)論