vue复习知识记录【1】 绑定字段、绑定事件、使用方法、使用计算

知识点:

  1、绑定一个字段,备注:js代码一定要在vue.js之后

    <div id="app">
       <input v-model="message">
    </div>
复制代码
    <script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>
    <script>
        var app=new Vue({
            el:"#app",
            data:{
                message:"welcome"
            }
        });
    </script>
复制代码

  2、把数据绑定到一个控件的属性上,但是不进行双向绑定,下面这段分别绑定到了这个input的value和name上

    <div id="app">
       <input v-bind:value="message" v-bind:name="message">
    </div>

  3、绑定一个事件

    <div id="app">
       <input  v-on:input="message=$event.target.value">
    </div>

  4、多级属性

复制代码
    <script>
        var app=new Vue({
            el:"#app",
            data:{
                loginForm:{
                    userName:"",
                    passWord:""
                }
            }
        });
    </script>
复制代码
       <div>
           <input v-model="loginForm.userName">
           <input v-model="loginForm.passWord">
       </div>

  5、绑定click事件,通过执行方法

       <div>
           <button v-on:click="submitForm">测试执行方法</button>
       </div>
复制代码
        var app=new Vue({
            el:"#app",
            data:{
                message:"welcome",
            },
            methods:{
                submitForm(){
                    console.log("执行方法成功!");
                }
            }
        });
复制代码

  6、在方法体里获得data里的值,备注:要使用 this关键字

            methods:{
                submitForm(){
                    console.log(this.loginForm.userName);
                }
            }

  7、this的作用域的范围之外,可以用下面这种方式获得data里的值

复制代码
            methods:{
                submitForm(){
                    var self=this;
                    var callFunction=function()
                    {
                        console.log(self.loginForm.userName);
                    }
                    callFunction();
                }
            }
复制代码

  8、也可以用下面这种方式获取,就是在方面的后面加上bind(this)

复制代码
            methods:{
                submitForm(){
                    var callFunction=function()
                    {
                        console.log(this.loginForm.userName);
                    }.bind(this);
                    callFunction();
                }
            }
复制代码

  9、还可以使用这种方式获取

复制代码
            methods:{
                submitForm(){
                    var callFunction=()=>
                    {
                        console.log(this.loginForm.userName);
                    };
                    callFunction();
                }
            }
复制代码

   10、使用computed,通过计算后返回需要的结果,备注:computed里的不是方法,而是字段,跟data下的字段的用法一样

复制代码
            data:{
                message:"welcome",
                loginForm:{
                    userName:"",
                    passWord:""
                },
                list:[
                    "a 1",
                    "a 2",
                    "b 3"
                ]
            },
复制代码
复制代码
            methods:{
                submitForm(){
                    var callFunction=()=>
                    {
                        console.log(this.loginForm.userName);
                    };
                    callFunction();
                }
            },
            computed:{
                filterList:function()
                {
                    return this.list.filter(x=>{
                        return x.indexOf("a")===0
                    })
                }
            }
复制代码
        <div>
            {{filterList}}
        </div>
posted @   星星c#  阅读(283)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示