Vue入门1

一、VueJs介绍

     Vue.js 是一个提供了 MVVM 风格的双向数据绑定的 Javascript 库,专注于View 层。它的核心是 MVVM 中的 VM, 也就是 ViewModel。 ViewModel负责连接 View 和 Model,保证视图和数据的一致性;

二、入门案例

      使用vue先引入vuejs-2.5.16.js的包;

     1.插值表达式

         (双大括号) 的文本插值

<body>
<div id="app">
    {{message}}  
    
    {{false ? "ok" : "false"}}
    
    {{number+520}}
div>
body>

<script>
    //view model
    //创建Vue对象
    new Vue({
        el: "#app",//由vue接管的id为app区域
        data: {
            message: "hello vue", //不加分号
            number: 100
        }
    });
script>

     2.常用系统指令

       2.1.v-on 

          可以用 v-on 指令监听 DOM 事件,并在触发时运行一些 JavaScript 代码;

          v-on  可以用  @ 代替;

       2.2.v-on:click (@click)       

    <body>
        <div id="app">
            {{message}}  
            <button v-on:click="fun1('Vue')">vue的onclickbutton>
        div>
    body>
<script>
        //view model
        new Vue({
            el:"#app",
            data:{
                message:"hello word"
            },
            methods:{
                fun1(msg) {
                    alert("hello");
                    this.message=msg;
                }
            }
        });
    script>

          2.3. v-on:keydown

<body>
        <div id="app">
            <div @mouseover="fun1" id="div">
                <textarea @mouseover="fun2($event)">这是一个文件域textarea>
            div>
        div>
    body>
    <script>
    
        new Vue({
            el:"#app",
            methods:{
                fun1:function () {
                    alert("鼠标到了div上");
                },
                fun2:function (event) {
                    alert("鼠标移到textarea上")
                    //停止事件 传播
                    event.stopPropagation();
                }
            }
        });
    script>

 

    2.4.v-mouseover(鼠标移动事件)

 

<body>
<div id="app">
    
    Vue:<input type="text" v-on:keydown="fun($event)">
div>
body>
<script>
    //view model
    new Vue({
        el: "#app",
        methods: {
            /*$event 是vue中的事件对象和传统js中的event对象一样*/
            fun(event) {
                var keyCode = event.keyCode;
                if (keyCode > 105 || keyCode < 96) {
                    //不让键盘的案件起作用
                    event.preventDefault();
                }
            }
        }
    });

script>

      

      2.5. @submit.prevent : 禁止访问

              @mouseover.stop : 禁止行为传播

<body>
<div id="app">
    <form action="http://www.itheima.com" method="post" @submit.prevent>
        <input type="submit" value="提交">
    form>
    <hr/>
    <div @mouseover="fun1" id="div">
          <textarea @mouseover.stop="fun2($event)">这是一个文本域textarea>
    div>
div>
body>
<script>
    //view model
    new Vue({
        el:"#app",
        methods:{
            fun1:function () {
                alert("鼠标到了div上");
            },
            fun2:function (event) {
                alert("鼠标移到textarea上");
            }
        }
    });
script>

       2.6. v-text 与 v-html      

    <body>
        <div id="app">
                     
            <div v-text="message">div>
                    
            <div v-html="message">div>
        div>
    body>
    <script>
        //view model
         new Vue({
             el:"#app",
             data:{
                 message:"

hello

" } }) script>

       2.7.v-bind

        注意:插值表达式不能用于html标签的属性取值,要给html的属性标签设置值,需要使用v-bind

      

<body>
    <div id="app">
        <font size="5" v-bind:color="ys1">aaaaaaafont>
        <font size="5" :color="ys2">bbbbbbbfont>
    div>
    body>
    <script>
        //view model
        // 插值表达式不能用于标签属性内部
        //v-bind简写为  :
        new Vue({
            el:"#app",
            data:{
                ys1:"red",
                ys2:"green"
            }
        })
    script>

       2.8. v-model :双向绑定;

           既可以设值,也可以读取值

    <body>
    <div id="app">
<form action="" method="post">
     用户名: <input type="text" name="username" v-model="user.username"><br/>
      密码:<input type="text" name="password" v-model="user.password"><br/>
     <button @click="fun">点击button>
form>
    div>
    body>
    <script>
             new Vue({
                 el:"#app",
                 data:{
                     user:{
                        username:"zhangsan",
                        password:"123"
                    }
                 },
                  methods:{
                      fun(){
                          alert(this.user.username);
                      }
                  }
             })
    script>

        2.9. v-for

 

<body>
        <div id="app">
            <ul>
                
                <li v-for="(key,value,index) in product" :key="index">{{index+1}}.{{key}}--->{{value}}li>
            ul>
        div>
    body>
    <script>
        //view model
        new Vue({
            el:"#app",
                data:{
                product:{
                    id:1,
                    name:"笔记本",
                    perice:5000
                }
                }
        })
    script>

       2.10.v-if 和 v-show 



<body>
        <div id="app">
            <span v-if="flag">aaaaaspan>
            <span v-show="!flag">bbbbbspan>
            <button @click="toggle">切换button>
 {{random}}
大于0.75 大于0.5 大于0.25 大于0

div> body> <script> //view model new Vue({ el:"#app", data:{ flag:false }, methods:{ toggle:function () { this.flag=!this.flag; } } }) script>
 
  

 

 

 

   

 

你可能感兴趣的:(Vue入门1)