苏飞论坛

标题: [Vue.js]学习笔记-Vue.js事件处理器-JavaScript事件使用 [打印本页]

作者: 范范    时间: 2018-12-17 14:11
标题: [Vue.js]学习笔记-Vue.js事件处理器-JavaScript事件使用
[Vue.js]学习笔记-Vue.js事件处理器-JavaScript事件使用




导读部分


讨论区:http://www.sufeinet.com/forum-58-1.html

教程目录:http://www.sufeinet.com/thread-24026-1-1.html


教程部分


Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。
另: Vue.js 的核心是一个允许你采用简洁的模板语法来声明式的将数据渲染进 DOM 的系统


Vue.js中事件监听使用v-on处理。
通常情况下, 直接在v-on中写事件方法不太现实, 毕竟很多页面方法内容很长,直接写到html页面上不方便, 也不舒服。 这个时候, 我们就需要使用一个方法来调用 JavaScript 方法v-on 可以接收一个定义的方法来调用

下面我通过一个实例, 来学下下JavaScript方法调用的方式。
实例:
[HTML] 纯文本查看 复制代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例 - 苏飞论坛(sufeinet.com)</title>
<script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>
</head>
<body>
<div id="app">
   <!-- `greet` 是在下面定义的方法名 -->
  <button v-on:click="greet">Greet</button>
</div>

<script>
var app = new Vue({
  el: '#app',
  data: {
    name: 'Vue.js'
  },
  // 在 `methods` 对象中定义方法
  methods: {
    greet: function (event) {
      // `this` 在方法里指当前 Vue 实例
      alert('Hello ' + this.name + '!')
      // `event` 是原生 DOM 事件
          if (event) {
                  alert('hello,苏飞论坛!')
          }
    }
  }
})
// 也可以用 JavaScript 直接调用方法
app.greet() // -> 'Hello Vue.js!'
</script>
</body>
</html>


通过上面的实例, 可以清晰的看到, 绑定了JavaScript方法, 是页面代码很整洁, 直接就使用v-on:click=“JavaScript方法名称” 就可以了, 此处实现的是click点击方法

作者: 范范    时间: 2018-12-17 14:11
除了直接绑定到一个方法,也可以用内联 JavaScript 语句

[HTML] 纯文本查看 复制代码
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 测试实例 - 苏飞论坛(sufeinet.com)</title>
<script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script>
</head>
<body>
<div id="app">
  <button v-on:click="say('hi')">Say hi</button>
  <button v-on:click="say('what')">Say what</button>
</div>

<script>
new Vue({
  el: '#app',
  methods: {
    say: function (message) {
      alert(message)
    }
  }
})
</script>
</body>
</html>


作者: 站长苏飞    时间: 2018-12-17 14:31
我只是路过打酱油的。
作者: liu    时间: 2018-12-17 14:47
感恩无私的分享与奉献
作者: 竹林风    时间: 2018-12-17 14:51
感恩无私的分享与奉献




欢迎光临 苏飞论坛 (http://www.sufeinet.com/) Powered by Discuz! X3.4