Vue.js如何实现select下拉列表-创新互联

这篇文章主要为大家展示了“Vue.js如何实现select下拉列表”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue.js如何实现select下拉列表”这篇文章吧。

十多年建站经验, 成都网站制作、成都网站建设、外贸营销网站建设客户的见证与正确选择。创新互联提供完善的营销型网页建站明细报价表。后期开发更加便捷高效,我们致力于追求更美、更快、更规范。

目标:用ul-li标签结合Vue.js知识做一个模仿select标签的下拉选项列表。

知识点:

组件的写法及运用

组件之间的数据传递(props的运用)

组件之间的数据传递($emit的运用)

动态数据的绑定(v-bind)

自定义事件通信

效果图:

1、未做任何操作前,下拉列表为隐藏状态

Vue.js如何实现select下拉列表

2、点击输入框显示下拉列表

Vue.js如何实现select下拉列表

3、 点击列表项,输入框值跟随改变

Vue.js如何实现select下拉列表

PS: 为了演示data1, data2两组数据的绑定,实例中创建了两个列表

Vue.js如何实现select下拉列表

html代码:




 
 ul-li模仿select下拉菜单
 
 


 
  
  
 

JavaScript代码


//注册全局组件
//在my-select组件中套用ul-select组件,my-select为父组件ul-select为子组件
Vue.component('my-select', {
 //组件中data要写成函数形式
 data() {
  return {
   ulShow: false, //默认ul不显示,单击input改变ul的显示状态
   selectVal: '' //选项值,input的值与选项值动态绑定
  }
 },
 //父组件向子组件通信用props
 props: ['btnName', 'list'],
 template: `
  
   
    
    
   
        
 `,  methods: {   changeVal(value) {    this.selectVal = value   }  } }) //子组件 Vue.component('my-ul', {  props: ['list'],  template: `       {{item}}     `,  methods: {   selectLi: function(item) {    //$emit触发当前实例上的自定义事件 receive    this.$emit('receive', item);   }  } }) //创建Vue实例 new Vue({  el: '#demo',  //定义两组数据分别传递到两个组件的li中,两个列表的操作互不影响  data: {   data1: ['CSS', 'HTML', 'JavaScript'],   data2: ['Vue.js', 'Node.js', 'Sass'],  } })

CSS样式

ul, li {
 margin: 0;
 padding: 0;
 list-style: none;
}
#selectWrap {
 width: 250px;
 padding: 2rem;
 background: #4682b4;
}
.searchBox input, .searchBox a {
 line-height: 1.5rem;
 height: 1.5rem;
 margin-bottom: 1rem;
 padding: 0 5px;
 vertical-align: middle;
 border: 1px solid #aaa;
 border-radius: 5px;
 outline: none;
}
.searchBox a {
 display: inline-block;
 text-decoration: none;
 background-color: #b1d85c;
}
.skill li {
 font-size: 18px;
 line-height: 2rem;
 height: 2rem;
 padding-left: 5px;
 cursor: pointer;
}
.skill li:hover {
 background-color: #008b45;
}

以上是“Vue.js如何实现select下拉列表”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联成都网站设计公司行业资讯频道!

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前文章:Vue.js如何实现select下拉列表-创新互联
网页URL:http://scyanting.com/article/djcjjj.html

其他资讯