请问如何实现点击一个按钮后,就产生一个蒙层?

发布于 2022-09-30 23:08:36 字数 5200 浏览 22 评论 0

image.png
请问如何实现如图所示的效果,点击某个按钮后就产生一个阴影层?
image.png
如图,我希望实现 处理底下几个icon图标外其余部分底部有蒙层,请赐教,不胜感激。

<template>
<div id="search">
  <el-input placeholder="请输入内容" v-model="input3" class="input-with-select" :style="{height: '45px'}">
    <div class="prepend" slot="prepend">
      <div class="imgIcon">
          <img src="../assets/juejin.png" class="imageIcon" title="掘金" alt="掘金"/>
      </div>
      <div class="el-icon-caret-bottom" @click="putList"
           :style="{fontSize: '20px',marginTop: '5px',cursor:'pointer'}"></div>

    </div>



    <!--    <el-select v-model="select" slot="prepend" placeholder="请选择分类维度">-->

<!--      <el-option value="1" :style="{display:'inline-block',height:'70px'}">-->
<!--        <slot>-->
<!--          <img src="../assets/baidu.png" title="百度" alt="百度"/>-->
<!--        </slot>-->
<!--      </el-option>-->
<!--      <el-option value="2" :style="{display:'inline-block',height:'70px'}">-->
<!--        <slot>-->
<!--          <img src="../assets/google.png" title="谷歌" alt="谷歌"/>-->
<!--        </slot>-->
<!--      </el-option>-->
<!--      <el-option value="3" :style="{display:'inline-block',height:'70px'}">-->
<!--        <slot>-->
<!--          <img src="../assets/juejin.png" title="掘金" alt="掘金"/>-->
<!--        </slot>-->
<!--      </el-option>-->

<!--    </el-select>-->
<!--&lt;!&ndash;    <el-button slot="append" icon="el-icon-search"></el-button>&ndash;&gt;-->
  </el-input>



  <div id="webList">
    <ul>
<!--      <li class="webList_item">-->
<!--        <img src="../assets/baidu.png"  title="百度" alt="百度"/>-->
<!--      </li>-->


      <li class="webList_item">
        <img src="../assets/baidu.png" class="webList_item" title="百度" alt="百度"/>
      </li>

      <li class="webList_item">
        <img src="../assets/github.png" class="webList_item" title="github" alt="github"/>
      </li>

      <li class="webList_item">
        <img src="../assets/juejin.png" class="webList_item" title="掘金" alt="掘金"/>
      </li>

      <li class="webList_item">
        <img src="../assets/google.png" class="webList_item" title="谷歌" alt="谷歌"/>
      </li>
    </ul>

  </div>


<!--  <el-dialog-->
<!--    title=""-->
<!--    :visible.sync="dialogVisible"-->
<!--    width="30%"-->
<!--    :before-close="handleClose">-->
<!--&lt;!&ndash;    <span>这是一段信息</span>&ndash;&gt;-->
<!--    <span slot="footer" class="dialog-footer">-->
<!--    <el-button @click="dialogVisible = false">取 消</el-button>-->
<!--    <el-button type="primary" @click="dialogVisible = false">确 定</el-button>-->
<!--  </span>-->
<!--  </el-dialog>-->





</div>
</template>

<script>
export default {
  name: "search",
  data() {
    return {
      dialogVisible: false,
      input3: '',
      // select:'1'
    }
  },
  methods: {
    handleClose(done) {
      this.$confirm('确认关闭?')
        .then(() => {
          done();
        })
        .catch(() => {
        });
    },

    putList(){
      var downIcon=document.getElementsByClassName('el-icon-caret-bottom')
      console.log(downIcon)
      downIcon[0].style=('transform:rotate(180deg);transition: 0.4s')
      this.dialogVisible = true
    }
  }



}
</script>




<style scoped>


div#webList{
  /*display: flex;*/
  padding:10px;
  margin:15px;
  cursor: pointer;
}

.webList_item{
  margin:8px;
  margin-right: 10px;
  border-radius: 2px;
  /*border: 1px solid ;*/
}

.webList_item:hover{
  font-weight: 500;
  background-color: lightblue;
  color: deepskyblue;
}

div.prepend{
  display: flex;
}

div.imgIcon{
  padding:0 6px;

}

img.imageIcon{
  width: 30px;
  height: 30px;
}

ul{
  border-radius: 2px;
  display: flex;
}


ul,li{
  list-style: none;
}

/deep/.el-input__icon{
  position: relative;
  margin-right: -130px;
  margin-top: 5px;
}

/*/deep/is-reserve{*/
/*  transform:none*/
/*}*/


/*.el-icon-caret-bottom:focus{*/
/*  transition: 0.4s;*/
/*  transform: rotate(180deg);*/
/*}*/


#search{
  margin:120px
}
.input-with-select{
  position: relative;
  width: 459px;
  height: 45px;
  margin-top: 2vw;
  background-color:#fff;
  border-radius:50px;

}
/deep/ .el-input-group__prepend {
  background-color: #F5F7FA;
  color: #909399;
   vertical-align: middle;
   display: table-cell;
  position: relative;
  border: 1px solid #DCDFE6;
  border-radius: 50px 0 0 50px;
  padding: 0 5px;
  width: 50px;
  height: 100%;
  white-space: nowrap;


}

img{
  width: 70px;
  height: 70px;
}


/deep/.el-input__inner{
  height: 45px;
}

</style>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

梦里泪两行 2022-10-07 23:08:36
<!DOCTYPE html>
<html>
<head>
    <title></title>
       <script language="javascript" type="text/javascript">
        function showdiv() {
            document.getElementById("bg").style.display ="block";
        }
        function hidediv() {
            document.getElementById("bg").style.display ='none';
        }
    </script>
    <style type="text/css">
        #bg{ display: none;  position: absolute;  top: 0%;  left: 0%;  width: 100%;  height: 100%;  background-color: black;  z-index:1001;  -moz-opacity: 0.7;  opacity:.70;  filter: alpha(opacity=70);}
        #show{display: none;  position: absolute;  top: 25%;  left: 22%; z-index: 9999; width: 53%;  height: 49%;  padding: 8px;  border: 8px solid #E8E9F7;  background-color: white;  z-index:1002;  overflow: auto;}
    </style>
</head>
<body>
<input id="btnshow" type="button" value="Show" onclick="showdiv();"/>
<div id="bg" onclick="hidediv();">
</div>    
</body>
</html>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文