3.vue基础(二)模板语法-数据绑定-el和data的两种写法-数据代理-事件处理

1.模板语法

包括插值语法和指令语法

<body>
    <!-- 准备好一个容器 -->
    <div id="root">
        <h1>hello,{{message}}</h1>//插值语法
        <a :href="url">点我去学习</a>//指令语法
    </div>

    <script type="text/javascript">
        Vue.config.productionTip = false;//阻止vue在启动时生成生产提示。
        // 创建vue实例
        const x = new Vue({
            el: '#root',//el用于指定当前vue实例为哪个容器服务,值通常为css选择器字符串
            data: {    //data中用于存储数据,数据供el所指定的容器去使用,值暂时写成一个对象
                message: '秦燕燕'url:'http://www.atguigu.com',
                
            }
        })
    </script>
</body>
  1. 使用vue,先必须创建一个vue实例,也就是new vue(),还要传入一个配置对象,也就是el:‘#root’

  2. Vue实例和容器是一一对应的

  3. 一旦data中的数据发生改变,那么页面中用到该数据的地方也会自动更新

  4. 插值语法:{{xxx}},{{xxx}}中的xxx也可以写js表达式,比如{{1+1}}

  5. 指令语法:

    v-bind:href = 'xxxx'
    

    xxxx 会作为 js 表达式被解析,

    v-bind:href = 'xxxx'可以简写成:href = 'xxxx'
    

2.数据绑定

2.1 单向绑定(v-bind)

数据只能从data流向页面。

使用方法:v-bind:value=“name”,可以简写为:value=“name”

<input type="text" :value="name"><br/>
<input type="text" v-bind:value="name">

2.2.双向绑定(v-model)

数据不仅能从data流向页面,还可以从页面流向data。

使用方法:v-model:value=‘xxxx’,可以简写为 v-model=‘xxxx’

一般都应用在表单类元素上(如:input、select等)

<input type="text" v-model="name">
<input type="text" v-model:value="name">

3.el和data的两种写法

3.1 el的两种写法

new Vue({
		el: '#root',
		data: {
			name: '你好'
		}
	})
const vm = new Vue({
		data: {
			name: '你好'
		}
	})
vm.$mount('#root')

3.2 data的两种写法

new Vue({
		el: '#root',
		//data的第一种写法:对象式
		data: {
			name: '你好'
		}
	})
	new Vue({
		el: '#root',
		//data的第二种写法:函数式
		data() {//也可以写成data:function(),但是不可能写箭头函数,因为一旦写了箭头函数,this就不再是Vue实例了
			console.log('@@@', this) //此处的this是Vue实例对象
			return {
				name: '秦燕燕'
			}
		}
	})

4.数据代理

4.1 关于Object.defineProperty

<script type="text/javascript" >
			let number = 18
			let person = {
				name:'张三',
				sex:'男',
			}

			Object.defineProperty(person,'age',{
				value:number,
				enumerable:true, //枚举
				writable:true, //修改
				configurable:true //删除
                
				//当有人读取person的age属性时,get函数(getter)就会被调用,且返回值就是age的值
				get(){
					console.log('有人读取age属性了')
					return number
				},

				//当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值
				set(value){
					console.log('有人修改了age属性,且值是',value)
					number = value
				}

			})

			// console.log(Object.keys(person))

			console.log(person)
		</script>

4.2 何为数据代理

通过一个对象代理对另一个对象中属性的操作(读/写)

			let obj = {x:100}
			let obj2 = {y:200}

			Object.defineProperty(obj2,'x',{
				get(){
					return obj.x
				},
				set(value){
					obj.x = value
				}
			})

4.3 vue中的数据代理

在这里插入图片描述

5.事件处理

5.1 点击事件

5.1.1 不传参数

<button v-on:click="showInfo">点我提示信息</button>
<button @click="showInfo">点我提示信息</button>
		methods: {
			showInfo(event) {
				console.log(event.target)//拿到这个按钮
                  console.log(event.target.innerText)//拿到这个按钮里的文字
				console.log(this) //此处的this是vm
				alert('秦燕燕你好!')
			}
		}

5.1.2 传参数

<button @click="showInfo2($event,66)">点我提示信息2(传参)</button>
methods: {
			showInfo2(event, number) {
				console.log(event, number)
				alert('秦燕燕你好!!')
			}
		}

5.2 事件修饰符

​ 1.prevent:阻止默认事件(常用);

​ 2.stop:阻止事件冒泡(常用);

​ 3.once:事件只触发一次(常用);

5.3 键盘事件

5.3.1 系统自带

<input type="text" placeholder="按下回车提示输入" @keyup.enter="showInfo">
    
    methods: {
        showInfo(e){
            console.log(e.target.value)
        }
    }

Vue中常用的按键别名

  1. 回车 => enter
  2. 删除 => delete (捕获“删除”和“退格”键)
  3. 退出 => esc
  4. 空格 => space
  5. 上 => up
  6. 下 => down
  7. ​ 左 => left
  8. ​ 右 => right
  9. ​ 换行 => tab (特殊,必须配合keydown去使用)

5.3.2 定制按键别名

Vue.config.keyCodes.自定义键名 = 键码
Vue.config.keyCodes.huiche = 13
<input type="text" placeholder="按下回车提示输入" @keydown.huiche="showInfo">
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值