开发避坑短篇(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样式限制的特殊语法,主要解决父组件修改子组件/第三方组件内部样式的需求‌。

相关推荐
DarkLONGLOVE2 天前
快速上手 Pinia!Vue3 极简状态管理使用教程
javascript·vue.js
宸翰2 天前
解决 uni-app App 端 vue-i18n 占位符丢失:封装跨端可用的 tf 格式化方法
前端·vue.js·uni-app
用户2136610035722 天前
VueRouter进阶-动态路由与嵌套路由
前端·vue.js
暴走的小呆2 天前
Vue 2 中 Object 的变化侦测:从 getter/setter 到 Dep、Watcher、Observer
vue.js
英勇无比的消炎药2 天前
TinyVue v-auto-tip: 文本超长自动提示的优雅方案
vue.js
时光足迹3 天前
腾讯云 TRTC UniApp SDK 从入门到上线
前端·vue.js·uni-app
时光足迹3 天前
uni-app 里把加密视频嵌入页面播放?我分析了 4 种方案,只有 1 种接近完美
前端·vue.js·uni-app
时光足迹3 天前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹3 天前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app
疯狂的魔鬼3 天前
一个"懂分寸"的文本省略组件是怎样炼成的
前端·vue.js·设计