Vue04-表单双绑、组件

表单双绑、组件

1、什么是双向数据绑定

Vue.js是一个MV VM框架, 即数据双向绑定, 即当数据发生变化的时候, 视图也就发生变化, 当视图发生变化的时候,数据也会跟着同步变化。这也算是Vue.js的精髓之处了。
值得注意的是,我们所说的数据双向绑定,一定是对于UI控件来说的非UI控件不会涉及到数据双向绑定。单向数据绑定是使用状态管理工具的前提。如果我们使用vue x那么数据流也是单项的,这时就会和双向数据绑定有冲突。

1.1 为什么要实现数据的双向绑定

Vue.js中,如果使用vuex, 实际上数据还是单向的, 之所以说是数据双向绑定,这是用的UI控件来说, 对于我们处理表单, Vue.js的双向数据绑定用起来就特别舒服了。即两者并不互斥,在全局性数据流使用单项,方便跟踪;局部性数据流使用双向,简单易操作。

2、在表单中使用双向数据绑定(v-model)

你可以用v-model指令在表单、及元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇, 但v-model本质上不过是语法糖。它负责监听用户的输入事件以更新数据,并对一些极端

注意:v-model会忽略所有表单元素的valuecheckedselected特性的初始值而总是将Vue实例的数据作为数据来源。你应该通过JavaScript在组件的data选项中声明初始值!

2.1 单行文本

<div id="hello">
    <p>
        <!--单行文本-->
        输入的文本:<input type="text" v-model="msg">{{msg}}
    </p>
</div>

<script src="../vue.js"></script>
<script>
    var vm = new Vue({
        el: '#hello',
        data: {
            msg: ''
        }
    });
</script>

2.2 多行文本

<div id="hello">
    <p>
        <!--多行文本-->
        输入的文本:<textarea v-model="msg"></textarea>{{msg}}
    </p>
</div>

<script src="../vue.js"></script>
<script>
    var vm = new Vue({
        el: '#hello',
        data: {
            msg: ''
        }
    });
</script>

2.3 单选框

<div id="hello">
    性别:
    <input type="radio" name="sex" value="" v-model="msg"><input type="radio" name="sex" value="" v-model="msg"><p>{{msg}}</p>
    
</div>

<script src="../vue.js"></script>
<script>
    var vm = new Vue({
        el: '#hello',
        data: {
            msg: ''
        }
    });
</script>

2.4 多选框

<div id="hello">
    爱好:
    <input type="checkbox" value="打游戏" v-model="msg"> 打游戏
    <input type="checkbox" value="学习" v-model="msg"> 学习
    <input type="checkbox" value="睡觉" v-model="msg"> 学习
    <p>{{msg}}</p>

</div>

<script src="../vue.js"></script>
<script>
    var vm = new Vue({
        el: '#hello',
        data: {
            msg: []
        }
    });
</script>

2.5 下拉框

<div id="hello">
    地址:
    <select v-model="msg">
        <option value="" disabled>--请选择--</option>
        <option>广东</option>
        <option>黑龙江</option>
        <option>广西</option>
    </select>
    <p>{{msg}}</p>

</div>

<script src="../vue.js"></script>
<script>
    var vm = new Vue({
        el: '#hello',
        data: {
            msg: ''
        }
    });
</script>

注意:v-model表达式的初始值未能匹配任何选项,元系将被渲染为“未选中”状态。 在iOS中, 这会使用户无法选择第一个选项,因为这样的情况下,iOS不会触发change事件。因此,更推荐像上面这样提供一个值为空的禁用选项。

3、组件

组件是可复用的Vue实例, 说白了就是一组可以重复使用的模板, 跟JSTL的自定义标签、Thymelealth:fragment等框架有着异曲同工之妙,通常一个应用会以一棵嵌套的组件树的形式来组织:

例如,你可能会有页头、侧边栏、内容区等组件,每个组件又包含了其它的像导航链接、博文之类的组件。

3.1 第一个 Vue 组件

注意:在实际开发中,我们并不会用以下方式开发组件,而是采用vue-cli创建,vue模板文件的方式开发,以下方法只是为了让大家理解什么是组件。

使用Vue.component()方法注册组件,格式如下:

<div id="hello">
    <aze/>
</div>

<script src="../vue.js"></script>
<script>
    Vue.component("aze",{
        template: '<h2>Hello,Vue!</h2>'
    });

    var vm = new Vue({
        el: '#hello'
    });
</script>

说明:

  • Vue.component():注册组件
  • pan:自定义组件的名字
  • template:组件的模板

3.2 使用 props 属性传递参数

像上面那样用组件没有任何意义,所以我们是需要传递参数到组件的,此时就需要使用props属性了!
注意:默认规则下props属性里的值不能为大写;

<div id="hello">
    <aze v-for="item in items" v-bind:abc="item"/>
</div>

<script src="../vue.js"></script>
<script>
    Vue.component("aze",{
        props: ['abc'],
        template: '<h2>{{abc}}</h2>'
    });

    var vm = new Vue({
        el: '#hello',
        data: {
            items: ["Java","C","Python"]
        }
    });
</script>

说明

  • v-for="item in items":遍历Vue实例中定义的名为items的数组,并创建同等数量的组件
  • v-bind:panh="item":将遍历的item项绑定到组件中props定义名为item属性上;= 号左边的panhprops定义的属性名,右边的为item in items 中遍历的item项的值
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 2.0 中,`v-model` 是一个非常强大的指令,用于实现数据绑定和表单输入的双向数据同步。自定义组件中使用 `v-model` 可以让你的用户输入自动更新组件的内部状态,并反之亦然。 以下是一个简单的自定义组件(例如一个名为 `CustomInput` 的输入框组件)的 `v-model` 示例: ```html <template> <div> <input type="text" v-model="inputValue"> <p>你输入的是: {{ inputValue }}</p> </div> </template> <script> export default { data() { return { inputValue: '', }; }, }; </script> ``` 在这个例子中: - `<input type="text" v-model="inputValue">`:将输入框的值绑定到 `inputValue` 数据属性上,用户在输入框中修改的任何内容都会实时更新 `inputValue`。 - `<p>你输入的是: {{ inputValue }}</p>`:当 `inputValue` 发生变化时,对应的文本也会根据新的值显示。 如果你在父组件中使用这个自定义组件: ```html <template> <div> <custom-input></custom-input> </div> </template> <script> import CustomInput from './CustomInput.vue'; export default { components: { CustomInput, }, }; </script> ``` 并且希望父组件的数据影响子组件,你可以在父组件的数据中设置默认值并传递给子组件: ```html <template> <div> <custom-input :value="parentValue"></custom-input> </div> </template> <script> export default { data() { return { parentValue: '初始值', }; }, components: { CustomInput: { props: ['value'], // 定义接收父组件传入的值 data() { return { inputValue: this.value, // 在子组件中设置默认值 }; }, }, }, }; </script> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值