开发避坑短篇(6):Vue+Element UI 深度选择器实现表单元素精准对齐的技术实践

需求

el-form 表单的el-input和el-select默认宽度度不一致,导致不对齐,如下图。那么如何设置让el-input和el-select的宽度度一致并对齐?

vue 复制代码
<el-form class="page-form" :model="addForm" :rules="rules" :disabled="flag" ref="addForm" >
    <el-row>
        <el-col :span="8">
            <el-form-item label="订单编号" prop="orderNo">
            <el-input v-model="form.orderNo" :placeholder="showInfo ? '' : '请输入订单编号'" />
            </el-form-item>
        </el-col>
        <el-col :span="8">
            <el-form-item label="订单状态" prop="status">
                <el-select v-model="form.status" clearable>
                    <el-option
                    v-for="dict in order_status"
                    :key="dict.value"
                    :label="dict.label"
                    :value="dict.value"
                    />
                </el-select>   
            </el-form-item>          
        </el-col> 
    </el-row>
</el-form>    

解决办法

(1)单行设置3列,

(2)在标签上设置属性label-position="left" label-width="100px",固定文本的对齐方式和宽度

(3)使用css深度选择器:deep(),统一设置表单元素的宽度

css 复制代码
/***修改input,select宽度 */
:deep(.el-collapse .el-input),
:deep(.el-collapse .el-select),
:deep(.el-collapse .el-date-editor){
  width: 450px;
}

注意,如果是el-dialog弹框页面上的表单,则需要用下面的方式修改

css 复制代码
/***修改弹框页面input,select宽度 */
:deep(.el-dialog__body .el-select),
:deep(.el-dialog__body .el-input){
  width: 400px;
}

当style标签有 scoped 属性时,它的 CSS 只作用于当前组件中的元素,父组件的样式将不会渗透到子组件。Vue中的:deep()深度选择器是用于穿透scoped样式限制的特殊语法,主要解决父组件修改子组件/第三方组件内部样式的需求‌。

相关推荐
军军君011 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
Hi_kenyon3 小时前
理解vue中的ref
前端·javascript·vue.js
AC赳赳老秦6 小时前
DeepSeek 辅助科研项目申报:可行性报告与经费预算框架的智能化撰写指南
数据库·人工智能·科技·mongodb·ui·rabbitmq·deepseek
毎天要喝八杯水7 小时前
搭建vue前端后端环境
前端·javascript·vue.js
Dontla9 小时前
Axure RP(Rapid Prototyper)原型图设计工具介绍
ui·axure·photoshop
晚霞的不甘9 小时前
Flutter for OpenHarmony从基础到专业:深度解析新版番茄钟的倒计时优化
android·flutter·ui·正则表达式·前端框架·鸿蒙
东东5169 小时前
果园预售系统的设计与实现spingboot+vue
前端·javascript·vue.js·spring boot·个人开发
怪兽毕设10 小时前
基于SpringBoot的选课调查系统
java·vue.js·spring boot·后端·node.js·选课调查系统
Amumu1213810 小时前
Vue Router(一)
前端·javascript·vue.js
切糕师学AI10 小时前
VSCode 下如何检查 Vue 项目中未使用的依赖?
vue.js·vscode