夜光带你走进Vue.js(七)擅长的领域

夜光序言:

 

她的泪,他看不见,却听得清,本想追回,却岿然成空。他只是在问良人为何不卷归;

她只是在终日苦盼,然而只有泪空垂。她不求殿宇宏,不求衣锦荣,只求能相伴他左右,但痴情却换来一身负累。

曾经的红尘眷恋,一任秋水望穿。

 

正文:参数

参数在指令后以冒号指明。

例如, v-bind 指令被用来响应地更新 HTML 属性:

提醒:在这里 href 是参数,告知 v-bind 指令将该元素的 href 属性与表达式 url 的值绑定。

 

另一个例子是 v-on 指令,它用于监听 DOM 事件:

修饰符

修饰符是以半角句号 . 指明的特殊后缀,用于指出一个指令应该以特殊方式绑定。例如,.prevent 修饰符告诉 v-on 指令对于触发的事件调用 event.preventDefault()

 

<form v-on:submit.prevent="onSubmit"></form>

嗯唔,这里要提一提:用户输入

在 input 输入框中我们可以使用 v-model 指令来实现双向数据绑定:

 

v-model 指令用来在 input、select、textarea、checkbox、radio 等表单控件元素上创建双向数据绑定,根据表单上的值,自动更新绑定的元素的值。

【开发中经常需要~~你懂的】

 

按钮的事件我们可以使用 v-on 监听事件,并对用户的输入进行响应。

以下实例在用户点击按钮后对字符串进行反转操作:

字符串反转

 

<template>
  <div id="app">
    <pre><a v-bind:href="url"></a> 夜光陪你学框架</pre>
    <p>{{msg}}</p>
    <input v-model="msg">
    <br>
    <button v-on:click="reverseMsg">反转字符串</button>
  </div>
</template>
<script>
  export default{
    data(){
      return{
        seen:true,
        url:"www.yeguang.com",
        msg:'夜光'
      }
    },
    methods:{
      reverseMsg:function () {
        this.msg = this.msg.split('').reverse().join('')
      }
    }
  }
</script>
<style>

</style>

过滤器

Vue.js 允许我们

自定义过滤器,被用作一些常见的文本格式化。


由"管道符"指示,我们来看一看    →  格式如下:

<!-- 在两个大括号中 -->
{{ message | capitalize }}

<!-- 在 v-bind 指令中 -->
<div v-bind:id="rawId | formatId"></div>

过滤器函数接受表达式的值作为第一个参数。

以下实例对输入的字符串第一个字母转为大写:


<template>
  <div id="app">
    <pre><a v-bind:href="url"></a> 夜光陪你学框架</pre>
    <p>{{msg}}</p>
    <input v-model="msg">
    <br>
    <button v-on:click="reverseMsg">反转字符串</button>
    <br>
    <br>
    {{msg | capitalize}}
  </div>
</template>
<script>
  export default{
    data(){
      return{
        seen:true,
        url:"www.yeguang.com",
        msg:'yeguang'
      }
    },
    methods:{
      reverseMsg:function () {
        this.msg = this.msg.split('').reverse().join('')
      },
    },filters:{
      capitalize:function (value) {
        if (!value) return '';
        value = value.toString();
        return value.charAt(0).toUpperCase() + value.slice(1)
      }
    }
  }
</script>
<style>

</style>

这里呢~~:过滤器可以串联:

{{ message | filterA | filterB }}

过滤器是 JavaScript 函数,因此可以接受参数:

{{ message | filterA('arg1', arg2) }}

这里,message 是第一个参数,字符串 'arg1' 将传给过滤器作为第二个参数, arg2 表达式的值将被求值然后传给过滤器作为第三个参数。


我们提一提:关于缩写

v-bind 缩写

Vue.js 为两个最为常用的指令提供了特别的缩写:

<!-- 完整语法 -->
<a v-bind:href="url"></a>
<!-- 缩写 -->
<a :href="url"></a>

v-on 缩写

<!-- 完整语法 -->
<a v-on:click="doSomething"></a>
<!-- 缩写 -->
<a @click="doSomething"></a>

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值