suchen

Heim  >  Fragen und Antworten  >  Hauptteil

javascript - Verwenden Sie vue.js, um den Effekt zu erzielen: Klicken Sie auf li, erhalten Sie den HTML-Wert des aktuellen Klicks auf li und wird der Parameter this zum Fensterobjekt?

Der zu erzielende Effekt:

Hauptcode

<body>
<p id="page">
    <ul>
        <li v-on:click="aa(this)" v-for="item in items">{{item}}</li>
    </ul>
</p>
<script type="text/javascript">
new Vue({
  el: '#page',
  data: {
        items:[11,22,33,44]
  },
  methods:{
    aa:function(obj){
        console.log(obj);  //打印出来的是 window对象?
        alert(obj.html());   //找不到点击的值;
    }
  }
})
</script>
</body>

Problembeschreibung:

Das nach dem Klicken auf li übergebene Objekt wird als Fensterobjekt und nicht als Li-Objekt gedruckt. Daher kann das Objekt nicht gefunden werden. Wie kann das aktuelle Li-Objekt an js übergeben werden?

曾经蜡笔没有小新曾经蜡笔没有小新2814 Tage vor1012

Antworte allen(4)Ich werde antworten

  • 高洛峰

    高洛峰2017-06-14 10:56:14

    看文档的时候看的仔细一点……不要臆想这些莫名其妙的用法。

    内联事件需要访问原始事件对象的时候,给里面加上$event参数就行了。像这样:

    <li v-on:click="aa($event)" v-for="item in items">{{item}}</li>

    你要拿到当前li标签的对象,读取事件对象下的currentTarget属性就行了,即event.currentTarget

    Antwort
    0
  • 女神的闺蜜爱上我

    女神的闺蜜爱上我2017-06-14 10:56:14

    <li @click="aa(item)" v-for="item in items">{{item}}</li>
    aa(item) {
      console.log(item) // 当前li的内容
    }

    Antwort
    0
  • ringa_lee

    ringa_lee2017-06-14 10:56:14

    给li加个ref属性 然后在methods中通过this.$refs拿到dom节点

    Antwort
    0
  • typecho

    typecho2017-06-14 10:56:14

    测试可行:

    <li @click="aa($event)" v-for="item in items">{{item}}</li>
      methods:{
        aa:function(event){
            console.log(event.target.innerHTML);
        }
      }
    

    Antwort
    0
  • StornierenAntwort