当前位置:Gxlcms > JavaScript > vue如何获取自定义元素属性参数值的方法

vue如何获取自定义元素属性参数值的方法

时间:2021-07-01 10:21:17 帮助过:5人阅读

偶尔还是会陷入到DOM操作上面去,其实你应该关心的是数据传递,而不是操作DOM。如果你是想获取data-num的数据,可以这样写:

  1. <span @click="getData($event,'21')">55</span>
  2. getData:function (e,num) {
  3. console.log(num)
  4. }

这样就可以取到这个值了,如果你是确实想操作DOM,那你可以这样写:

  1. <span data-num="21" ref="dataNum" @click="getData($event)">55</span>
  2. getData:function (e) {
  3. console.log(this.$refs.dataNum.dataset.num);
  4. }

2.通过e.target.getAttribute

  1. <div id="app">
  2. <span data-num="21" @click="getData($event)">55</span>
  3. </div>
  1. new Vue({
  2. el:'#app',
  3. methods:{
  4. getData:function (e) {
  5. console.log(e.target.getAttribute('data-num'))
  6. }
  7. }
  8. })

3.自定义命名

如:html 

  1. <div class="live-dd" numId = "<{$item.id}>"></div>

js:

  1. $('.live-dd').on("click",function(){var num = this.getAttribute('numId');location.href='/live/info?id='+num;})

使用jq的方法

  1. <span class="vk_cq5" classid="<{$smarty.get.id}>">
  2. var live_id = $('.vk_cq5').attr('classid')

ref的用法  相当于操作dom
html :

  1. <div>
  2. <div id="box" ref="mybox">
  3. DEMO
  4. </div>
  5. </div>

js:

  1. export default {  
  2.   data () {  
  3.     return {  
  4.         
  5.     }  
  6.   },  
  7.   mounted () {  
  8.     this.init();  
  9.   },  
  10.   methods:{  
  11.     init() {  
  12.       const self = this;  
  13.       this.$refs.mybox.style.color = 'red';  
  14.       setTimeout(() => {  
  15.         self.$refs.mybox.style.color = 'blue';  
  16.       },2000)  
  17.     }  
  18.   }  
  19.   
  20. }  

以上所述是小编给大家介绍的vue如何获取自定义元素属性参数值的方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

人气教程排行