Detailed explanation of how to modify the style of el-select: popper-append-to-body and popper-class

Detailed explanation of how to modify the style of el-select: popper-append-to-body and popper-class

How to modify the style of the el-select component provided by elementUI

There are many solutions to this problem on the Internet:

1. Find the class name of the drop-down box and write a全局樣式覆蓋it.
2. Modify the style of .el-select-dropdown__item
3. Modify the style through popper-class provided by the official website

However, the above method does not hit the point. Overriding the global style is definitely not user-friendly, and modifying the style and adding classes do not work either. So, I looked at the style of the drop-down box. It was not in el-select , but placed on the outermost layer, as shown below:

Then I went to the official website to see if there is a property to control it, and sure enough, there is such a person popper-append-to-body :

The default value is true , change it to false to make it work

HTML

<el-select
    :popper-append-to-body="false"
    v-model="taskType"
    placeholder="Please select"
    size="mini"
    class="select-style"
    popper-class="select-popper"
  >
    <el-option
      v-for="(item,index) in taskTypes"
      :key="index"
      :value="item.value"
      :label="item.label"
    ></el-option>
  </el-select>

The code structure is as follows:

In fact, this only changes the style inside the drop-down box. The style of the input box also needs to be modified by modifying the .el-input__inner style:

CSS

.select-style {
    width: 3rem;
    margin-right: 0.36rem;
    /deep/.el-input__inner {
      border-top-left-radius: 0;
      border-bottom-left-radius: 0;
      border: 1px solid #a1a3ad;
      border-left-width: 0;
      background-color: rgba(0, 0, 0, 0.8);
      font-family: PingFangSC-Regular;
      font-size: 0.28rem;
      color: rgba(255, 255, 255, 0.6);
    }
  }

Finally, attach the style of .select-popper :

/deep/.select-popper {
    background-color: $item-bg-color;
    border-radius: 0.08rem;
    border: solid 0.02rem #1c395d;
    font-family: PingFangSC-Regular;
    .el-select-dropdown__item.selected {
      font-family: PingFangSC-Regular;
      font-size: 0.28rem;
      color: rgba(74, 141, 253, 1);
    }
    li {
      color: #fff;
      background: transparent;
      color: #fff;
      font-size: 0.28rem;
    }
    .el-select-dropdown__item:hover,
    .el-select-dropdown__item.hover {
      background-color: rgba(110, 147, 206, 0.2);
      margin-right: 1px;
    }
    .popper__arrow::after {
      border-bottom-color: $item-bg-color;
    }
    .popper__arrow {
      border-bottom-color: $item-bg-color;
    }
    .el-select-dropdown__empty {
      padding: 0.2rem;
      font-size: 0.28rem;
    }
  }

Summarize

Key point: :popper-append-to-body="false" , then add popper-class to modify the style.

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

<<:  Professional and non-professional web design

>>:  JavaScript Basics: Immediate Execution Function

Recommend

Chrome 4.0 supports GreaseMonkey scripts

GreaseMokey (Chinese people call it Grease Monkey...

Introduction to Nginx regular expression related parameters and rules

Preface Recently, I have been helping clients con...

Web lesson plans, lesson plans for beginners

Teaching Topics Web page Applicable grade Second ...

How to detect if the current browser is a headless browser with JavaScript

Table of contents What is a headless browser? Why...

Commands to find domain IP address in Linux terminal (five methods)

This tutorial explains how to verify the IP addre...

Analysis of MySQL crash recovery based on Redo Log and Undo Log

Table of contents MySQL crash recovery process 1....

How to change apt-get source in Ubuntu 18.04

When using apt-get to install, it will be very sl...

Build a severe weather real-time warning system with Node.JS

Table of contents Preface: Step 1: Find the free ...

26 Commonly Forgotten CSS Tips

This is a collection of commonly used but easily ...

mysql-8.0.17-winx64 deployment method

1. Download mysql-8.0.17-winx64 from the official...

Web developers are concerned about the coexistence of IE7 and IE8

I installed IE8 today. When I went to the Microso...

Implementation of Docker packaging image and configuration modification

I have encountered many problems in learning Dock...

MySQL 5.7.15 version installation and configuration method graphic tutorial

This article shares with you a detailed tutorial ...