首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >bootstrap-使用font-awsome为下拉图标选择库

bootstrap-使用font-awsome为下拉图标选择库
EN

Stack Overflow用户
提问于 2018-12-14 03:49:21
回答 2查看 2.3K关注 0票数 0

我正在使用bootstrap-select作为我正在做的搜索UI,一切都运行得很好,这个库有很多很好的选项。我想要替换默认的下拉图标到我的字体可怕的图标,这样我就可以控制图标的样式。我已经尝试了他们默认的图标改变方式,这是不起作用的,我在这里做错了什么。

默认图标

所需图标

这是我尝试过的图标更改功能,但没有成功

代码语言:javascript
复制
    $('.selectpicker').selectpicker({
        iconBase: 'fa',
        tickIcon: 'fa-chevron-down',
     });

有没有一种css方法可以做到这一点?如果有像上面这样的工作函数,那就更好了。

这里是我目前为止的工作,

代码语言:javascript
复制
.dnow-searchWizard-wrap .dropdown.bootstrap-select button.btn-light {
  background-color: #fff;
  padding: 1rem;
}
.dnow-searchWizard-wrap .btn-primary {
  padding: 1rem;
}
代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">

<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>slick slider</title>
   <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm"
      crossorigin="anonymous">
   <link href="https://unpkg.com/ionicons@4.4.8/dist/css/ionicons.min.css" rel="stylesheet">

   <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.2/css/bootstrap-select.min.css">


   <link rel="stylesheet" href="css/style.css">
</head>

<body>

   <section class="dnow-searchWizard-wrap bg-light p-5">
      <div class="container">
         <div class="row text-center">
            <div class="col-lg-12 mb-4">
               <h2>H2 Find Solutions That Work for You</h2>
            </div>
            <div class="col-lg-12 mb-4">
               <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit do eiusmod.</p>
            </div>
         </div>
         <div class="row">
            <div class="col-lg-2 align-self-center">
               <p><strong>I AM LOOKING FOR</strong></p>
            </div>
            <div class="col-lg-3">
               <div class="form-group">
                  <select class="selectpicker form-control">
                     <optgroup label="Picnic">
                        <option>Mustard</option>
                        <option>Ketchup</option>
                        <option>Relish</option>
                     </optgroup>
                     <optgroup label="Camping">
                        <option>Tent</option>
                        <option>Flashlight</option>
                        <option>Toilet Paper</option>
                     </optgroup>
                  </select>
               </div>

            </div>
            <div class="col-lg-1 align-self-center text-center">
               <p><strong>IN</strong></p>
            </div>
            <div class="col-lg-3">
               <div class="form-group">
                  <select class="selectpicker form-control">
                     <optgroup label="Picnic">
                        <option>Mustard</option>
                        <option>Ketchup</option>
                        <option>Relish</option>
                     </optgroup>
                     <optgroup label="Camping">
                        <option>Tent</option>
                        <option>Flashlight</option>
                        <option>Toilet Paper</option>
                     </optgroup>
                  </select>
               </div>

            </div>
            <div class="col-lg-3">
               <button class="btn btn-primary">Show My Results</button>

            </div>

         </div>

      </div>
   </section>

   <script src="https://code.jquery.com/jquery-3.2.1.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN"
      crossorigin="anonymous"></script>
   <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js" integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
      crossorigin="anonymous"></script>
   <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
      crossorigin="anonymous"></script>
   <!-- Latest compiled and minified JavaScript -->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.2/js/bootstrap-select.min.js"></script>

   <!-- (Optional) Latest compiled and minified JavaScript translation files -->
   <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.2/js/i18n/defaults-*.min.js"></script>

   <script>
      $(document).ready(function () {
         $('.selectpicker').selectpicker({
            iconBase: 'fa',
            tickIcon: 'fa-check',
         });
      });

   </script>
</body>

</html>

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-01-16 00:18:21

bootstrap 4使用边框技巧添加下拉图标,因此在使用dropdown ::after添加我自己的图标后,我必须将所有边框覆盖为none以删除默认图标。您可以对drop up执行相同的操作。

代码语言:javascript
复制
.dropdown-toggle::after {
    font-family: "Ionicons";
    /* display: inline-block; */
    content: '\f123';
    /* width: 0;
    height: 0;
    margin-left: 0.255em;
    vertical-align: 0.255em; */
    border-top: none;
    border-right: none;
    border-bottom: none;
    border-left: none;
    margin-right: 1rem;
}

.dropup .dropdown-toggle::after {
    /*display: inline-block;
    width: 0;
    height: 0;
    margin-left: .255em;
    vertical-align: .255em;*/
    font-family: "Ionicons";
    content: "\f126";
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
}
票数 0
EN

Stack Overflow用户

发布于 2018-12-14 06:25:02

可以使用下面的css对矢量图像执行此操作。也可以使用‘:after’和'content‘样式,但我还没有尝试过。如果没有其他人提供帮助,我至少给了你一个可行的解决方案。

代码语言:javascript
复制
.changedSelect {
    padding: 0 32px 0 5px !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: white;
    background-image: url('../DropDownArrow.png');
    background-repeat: no-repeat;
    background-position: right 5px center;
    background-size: 20px 20px;
}

/*Hide the original drop down arrow on internet explorer*/
.changedSelect::-ms-expand {
    display: none;
};

更新:作为一个令人惊叹的人,浏览器不允许你在select上使用:after和content CSS添加一个令人敬畏的字体图标,这意味着据我所知,我发布的解决方案将是添加自定义箭头的唯一方法,除非你添加一个包装器。根据从IvanS添加的注释,可以使用之前和之后向普通div添加字体令人敬畏的图标

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53769097

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档