zoukankan      html  css  js  c++  java
  • vue笔记(一)

    Vue的开发

    一丶下载

    # 中文下载地址: https://cn.vuejs.org/
    
    # 使用方式:
    	# 1. 单独使用 vue.min.js。文件
    	# 2. 结合node.js使用集成工具
    

    二丶vue的基本使用

    基本案例

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script src="js/vue.js"></script>
        <script>
        window.onload = function(){
          	// vue.js的代码开始于一个Vue对象。所以每次操作数据都要声明Vue对象开始。
            // 1.实例化一个vue对象,里面的参数都是以键值对形式存在
            var vm = new Vue({
                el:'#app',   // 设置当前vue对象要控制的标签范围。 2. 绑定一个最外层标签
                data:{  // data是将要展示到HTML标签元素中的数据。 3. 给页面返回数据 
                  message: 'hello world!',
                }
            });
        }
        </script>
    </head>
    <body>
    <div id="app">
        <!-- {{ message }} 表示把vue对象里面data属性中的对应数据输出到页面中 -->
        <!-- 在双标签中显示数据要通过{{  }}来完成 -->
        <p>{{ message }}</p>
    </div>
    </body>
    </html>
    

    总结

    1. vue的使用要从创建Vue对象开始
       var vm = new Vue();
       
    2. 创建vue对象的时候,需要传递参数,是json对象,json对象对象必须至少有两个属性成员
       var vm = new Vue({
         el:"#app",
    	 	 data: {
             数据变量:"变量值",
             数据变量:"变量值",
             数据变量:"变量值",
         },
       });
       
       el:设置vue可以操作的html内容范围,值一般就是css的id选择器。
       data: 保存vue.js中要显示到html页面的数据。
       
    3. vue.js要控制器的内容外围,必须先通过id来设置。
      <div id="app">
          <h1>{{message}}</h1>
          <p>{{message}}</p>
      </div>
    

    三丶vue.js的M-V-VM思想

    # MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式。
    
     # 1.`Model`:  指代的就是vue对象的data属性里面的数据。这里的数据要显示到页面中。
    
     # 2.`View` : 指代的就是vue中数据要显示的HTML页面,在vue中,也称之为“视图模板” 。
    
     # 3.`ViewModel ` 指代的是vue.js中我们编写代码时的vm对象了,它是vue.js的核心,负责连接 View 和 Model,保证视图和数据的一致性,所以前面代码中,data里面的数据被显示中p标签中就是vm对象自动完成的。
    

    基本案例

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.min.js"></script>
        <script>
        window.onload = function(){
            // 创建vm对象
            var vm = new Vue({
                el: "#app",
                data: {
                    name:"大标题",
                    age:16,
                },
            })
        }
        </script>
    </head>
    <body>
        <div id="app">
            <!-- 在双标签中显示数据要通过{{  }}来完成 -->
            <h1>{{name}}</h1>
            <p>{{age}}</p>
            <!-- 在表单输入框中显示数据要使用v-model来完成,模板语法的时候,我们会详细学习 -->
            <input type="text" v-model="name">
        </div>
    </body>
    </html>
    

    vm对象可以直接访问el和data属性

    # 可以访问data里面的数据
    console.log(vm.$el)     # #box  vm对象可以控制的范围
    console.log(vm.$data);  # vm对象要显示到页面中的数据
    console.log(vm.$data.message);  # 访问data里面的数据
    console.log(vm.message);# 这个 message就是data里面声明的数据,也可以使用 vm.变量名显示其他数据,message只是举例.
    

    {{}} 和 v-model

    ## 
    	1. 在双标签中显示数据要通过{{  }}来完成数据显示
    	2. 在表单输入框中显示数据要使用v-model来完成数据显示
    
    1. 如果要输出data里面的数据作为普通标签的内容,需要使用{{  }}
       用法:
          vue对象的data属性:
              data:{
                name:"小明",
              }
          标签元素:
          		<h1>{{ name }}</h1>
    2. 如果要输出data里面的数据作为表单元素的值,需要使用vue.js提供的元素属性v-model
       用法:
          vue对象的data属性:
              data:{
                name:"小明",
              }
          表单元素:
          		<input v-model="name">
          
       使用v-model把data里面的数据显示到表单元素以后,一旦用户修改表单元素的值,则data里面对应数据的值也会随之发生改变,甚至,页面中凡是使用了这个数据都会发生变化。
    
    

    四丶vue常用指令

    操作属性

    # 语法: <标签名 :标签属性="data属性"></标签名>
    
    # 案例:
    <p :title="str1">{{ str1 }}</p> <!-- 也可以使用v-html显示双标签的内容,{{  }} 是简写 -->
    <a :href="url2">淘宝</a>
    <a v-bind:href="url1">百度</a>  <!-- v-bind是vue1.x版本的写法 -->
    
    

    事件绑定

    # 语法: 
    	 # 1.@事件名 
    	 # 2.v-on:事件名
    	 
    # 案例:
    
        # 1. 使用@事件名来进行事件的绑定
           语法:
              <h1 @click="num++">{{num}}</h1>
    
        # 2. 绑定的事件的事件名,全部都是js的事件名:
           @submit   --->  onsubmit
           @focus    --->  onfocus
    
    
    

    完成商城购物车中的商品增加减少数量

    ### 1. 给vue对象添加操作数据的方法
    ### 2. 在标签中使用指令调用操作数据的方法
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.js"></script>
    </head>
    <body>
        <div id="box">
            <button @click="++num">+</button>
            <input type="text" v-model="num">
            <button @click="sub">-</button>
        </div>
    
        <script>
            let vm = new Vue({
                el:"#box",
                data:{
                    num:0,
                },
                methods:{
                    sub(){
                        if(this.num<=1){
                            this.num=0;
                        }else{
                            this.num--;
                        }
                    }
                }
            })
        </script>
    </body>
    </html>
    
    <!--#box>(button+input+button) tab键-->
    
    
    

    控制标签class类名

    # 格式:
       <h1 :class="值">元素</h1>  值可以是字符串、对象、对象名、数组
    
    
    # 案例一:  添加class类名,值是一个对象
    <div id="box">
            <!--- 添加class类名,值是一个对象
            {
             class类1:布尔值变量1,
             class类2:布尔值变量2,
            }
             -->
            <p :class="{box1:myclass1}">一个段落</p>
            <p @click="myclass3=!myclass3" :class="{box1:myclass2,box2:myclass3}">一个段落</p>
        </div>
        
    <script>
            let vm1=new Vue({
                el:"#box",
                data:{
                    myclass1:false, // 布尔值变量如果是false,则不会添加对象的属性名作为样式
                    myclass2:true,  // 布尔值变量如果是true,则不会添加对象的属性名作为样式
                    myclass3:false,
                },
            })
        </script>
        
    
    
    # 案例 二
    
    <div id="app">
            <button @click="mycls.box4=!mycls.box4">改变背景</button>
            <button @click="mycls.box5=!mycls.box5">改变字体颜色</button>
            <p :class="mycls">第二个段落</p>
    </div>
    
    <script>
            let vm2 = new Vue({
                el:"#app",
                data:{
                    // json 格式 调用
                    mycls:{
                        box4:false,
                        box5:true
                    },
                }
            })
    </script>
    
    
    # 案例三: 批量给元素增加多个class样式类
    <div id="app2">
                <p :class="[mycls1,mycls2]">第三个段落</p>
    </div>
    <script>
            let vm3 = new Vue({
                el:"#app2",
                data:{
                    mycls1:{
                        box6:true,
                        box7:true,
                    },
                    mycls2:{
                        box8:true,
                    }
                }
            })
    </script>
    
    

    控制标签style样式

    格式1:值是json对象,对象写在元素的:style属性中
    	 标签元素:
    		     <div :style="{color: activeColor, fontSize: fontSize + 'px' }"></div>
    	 data数据如下:
             data: {
                 activeColor: 'red',
                 fontSize: 30
             }
    格式2:值是对象变量名,对象在data中进行声明
       标签元素:
       			<div v-bind:style="styleObject"></div>
       data数据如下:
             data: {
                	styleObject: {
                 		color: 'red',
                 		fontSize: '13px'
    			  	}
    		}
    
    格式3:值是数组
      标签元素:
    				<div v-bind:style="[style1, style2]"></div>
    	data数据如下:
    				data: {
                         style1:{
                           color:"red"
                         },
                         style2:{
                           background:"yellow",
                           fontSize: "21px"
                         }
    				}
    
    

    条件渲染指令

    # v-if 指令
      标签元素:
          <!-- vue对象最终会把条件的结果变成布尔值 -->
    			<h1 v-if="ok">Yes</h1>
      data数据:
      		data:{
          		ok:false    // true则是显示,false是隐藏
          }
    
    
    # v-if  v-else-if  v-else 指令
        <h1 v-if="num==1">num的值为1</h1>
        <h1 v-else-if="num==2">num的值为2</h1>
        <h1 v-else>num的值是{{num}}</h1>
    
    
    # v-show 指令
        用法和v-if大致一样,区别在于2点:
        1. v-show后面不能v-else或者v-else-if
        2. v-show隐藏元素时,使用的是display:none来隐藏的,而v-if是直接从HTML文档中移除元素[ DOM操作中的remove ] 
    
    
      标签元素:
    			<h1 v-show="ok">Hello!</h1>
      data数据:
      		data:{
          		ok:false    // true则是显示,false是隐藏
          }
    
    

    列表渲染指令

    # 在vue中,可以通过v-for指令可以将一组数据渲染到页面中,数据可以是数组或者对象。
    
    数据是数组:        
            <ul>
                <!--book是列表的每一个元素-->
                <li v-for="book in book_list">{{book.title}}</li>
            </ul>
    
            <ul>
                <!--book是列表的每一个元素,index是每个元素的下标-->
                <li v-for="book, index in book_list">第{{ index+1}}本图书:{{book.title}}</li>
            </ul>
    
    
            <script>
                var vm1 = new Vue({
                    el:"#app",
                    data:{
                        book_list:[
                            {"id":1,"title":"图书名称1","price":200},
                            {"id":2,"title":"图书名称2","price":200},
                            {"id":3,"title":"图书名称3","price":200},
                            {"id":4,"title":"图书名称4","price":200},
                        ]
                    }
                })
            </script>
    
    数据是对象:
            <ul>
                <!--i是每一个value值-->
                <li v-for="value in book">{{value}}</li>
            </ul>
            <ul>
                <!--i是每一个value值,j是每一个键名-->
                <li v-for="attr, value in book">{{attr}}:{{value}}</li>
            </ul>
            <script>
                var vm1 = new Vue({
                    el:"#app",
                    data:{
                        book: {
                            // "attr":"value"
                            "id":11,
                            "title":"图书名称1",
                            "price":200
                        },
                    },
                })
            </script>
    
    
    

    五丶Vue对象提供的属性功能

    过滤器Vue.filter()进行全局定义

    Vue.filter("RMB1", function(v){
      	//就是来格式化(处理)v这个数据的
      	if(v==0){
        		return v;
      	}
    
      	return v+"元";
    })
    
    

    在vue对象中通过filters属性来定义

    var vm = new Vue({
      el:"#app",
      data:{},
      filters:{
        RMB2:function(value){
          if(value==''){
            return;
          }else{
          	return '¥ '+value;
          }
        }
    	}
    });
    
    

    计算和侦听属性 computed:{}

    vue提供了一个计算属性(computed),可以让我们把调整data数据的代码存在在该属性中
    
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.min.js"></script>
    		<script>
    		window.onload = function(){
            var vm = new Vue({
                el:"#app",
                data:{
                    str1: "abcdefgh"
                },
                computed:{   //计算属性:里面的函数都必须有返回值
                    strRevs: function(){
                        var ret = this.str1.split("").reverse().join("");
                        return ret
                    }
                }
            });
        }
        </script>
    </head>
    <body>
        <div id="app">
             <p>{{ str1 }}</p>
             <p>{{ strRevs }}</p>
        </div>
    </body>
    </html>
    
    

    监听属性

    # 侦听属性,可以帮助我们侦听data某个数据的变化,从而做相应的自定义操作。
    
    # 侦听属性是一个对象,它的键是要监听的对象或者变量,值一般是函数,当侦听的data数据发生变化时,会自定执行的对应函数,这个函数在被调用时,vue会传入两个形参,第一个是变化前的数据值,第二个是变化后的数据值。
    
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.min.js"></script>
        <script>
          window.onload = function(){
             var vm = new Vue({
                el:"#app",
                data:{
                    num:20
                },
                watch:{
                    num:function(newval,oldval){
                        //num发生变化的时候,要执行的代码
                        console.log("num已经发生了变化!");
                    }
                }
            })
          }
        </script>
    </head>
    <body>
        <div id="app">
            <p>{{ num }}</p>
            <button @click="num++">按钮</button>
        </div>
    </body>
    </html>
    
    

    六丶vue对象的生命周期

    vue的声明周期

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/vue.min.js"></script>
        <script>
        window.onload = function(){
            var vm = new Vue({
                el:"#app",
                data:{
                    num:0
                },
                beforeCreate:function(){
                    console.log("beforeCreate,vm对象尚未创建,num="+ this.num);  //undefined
                    this.name=10; // 此时没有this对象呢,所以设置的name无效,被在创建对象的时候被覆盖为0
                },
                created:function(){
                    console.log("created,vm对象创建完成,设置好了要控制的元素范围,num="+this.num );  // 0
                    this.num = 20;
                },
                beforeMount:function(){
                    console.log( this.$el.innerHTML ); // <p>{{num}}</p>
                    console.log("beforeMount,vm对象尚未把data数据显示到页面中,num="+this.num ); // 20
                    this.num = 30;
                },
                mounted:function(){
                    console.log( this.$el.innerHTML ); // <p>30</p>
                    console.log("mounted,vm对象已经把data数据显示到页面中,num="+this.num); // 30
                },
                beforeUpdate:function(){
                    // this.$el 就是我们上面的el属性了,$el表示当前vue.js所控制的元素#app
                    console.log( this.$el.innerHTML );  // <p>30</p>
                    console.log("beforeUpdate,vm对象尚未把更新后的data数据显示到页面中,num="+this.num); // beforeUpdate----31
                    
                },
                updated:function(){
                    console.log( this.$el.innerHTML ); // <p>31</p>
                    console.log("updated,vm对象已经把过呢更新后的data数据显示到页面中,num=" + this.num ); // updated----31
                },
            });
        }
        </script>
    </head>
    <body>
        <div id="app">
            <p>{{num}}</p>
            <button @click="num++">按钮</button>
        </div>
    </body>
    </html>
    
    

    ​ 总结

    # 在vue使用的过程中,如果要初始化操作,把初始化操作的代码放在 mounted 中执行。
    # mounted阶段就是在vm对象已经把data数据实现到页面以后。一般页面初始化使用。例如,用户访问页面加载成功以后,就要执行的ajax请求。
    
    # 另一个就是created,这个阶段就是在 vue对象创建以后,把ajax请求后端数据的代码放进 created
    
    

    阻止事件冒泡和刷新页面

    # .stop和.prevent
    
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .box1{
                 200px;
                height: 200px;
                background: #ccc;
            }
            .box2{
                 100px;
                height: 100px;
                background: pink;
            }
        </style>
        <script src="js/vue.min.js"></script>
        <script>
        window.onload = function(){
            var vm = new Vue({
                el:"#app",
                data:{}
            })        
        }
        </script>
    </head>
    <body>
        <div id="app">
            <div class="box1" @click="alert('box1')">
                <div class="box2" @click.stop.prevent="alert('box2')"></div>   <!-- @click.stop来阻止事件冒泡 -->
            </div>
    
            <form action="#">
                <input type="text">
                <input type="submit">
                <input type="submit" value="提交02" @click.prevent=""> <!-- @click.prevent来阻止表单提交 -->
            </form>
        </div>
    
    </body>
    </html>
    
    

    七丶通过axios实现数据请求

    vue.js默认没有提供ajax功能的。
    
    所以使用vue的时候,一般都会使用axios的插件来实现ajax与后端服务器的数据交互。
    
    注意,axios本质上就是javascript的ajax封装,所以会被**同源策略**限制。
    
    插件: http://www.axios-js.com/
    
    # 下载地址:
    
    
    https://unpkg.com/axios@0.18.0/dist/axios.js
    https://unpkg.com/axios@0.18.0/dist/axios.min.js
    ​```
    
    

    axios提供发送请求的常用方法有两个:axios.get() 和 axios.post() 。

    增   post
    
    删   delete
    
    改   put/patch
    
    查   get 
    
    
    ​```vue
    	// 发送get请求
        // 参数1: 必填,字符串,请求的数据接口的url地址,例如请求地址:http://www.baidu.com?id=200
        // 参数2:可选,json对象,要提供给数据接口的参数
        // 参数3:可选,json对象,请求头信息
    	axios.get('服务器的资源地址',{ // http://www.baidu.com
        	params:{
        		参数名:'参数值', // id: 200,
        	}
        
        }).then(function (response) { // 请求成功以后的回调函数
        		console.log("请求成功");
        		console.log(response.data); // 获取服务端提供的数据
        
        }).catch(function (error) {   // 请求失败以后的回调函数
        		console.log("请求失败");
        		console.log(error.response);  // 获取错误信息
        });
    
    	// 发送post请求,参数和使用和axios.get()一样。
        // 参数1: 必填,字符串,请求的数据接口的url地址
        // 参数2:必填,json对象,要提供给数据接口的参数,如果没有参数,则必须使用{}
        // 参数3:可选,json对象,请求头信息
        axios.post('服务器的资源地址',{
        	username: 'xiaoming',
        	password: '123456'
        },{
            responseData:"json",
        })
        .then(function (response) { // 请求成功以后的回调函数
          console.log(response);
        })
        .catch(function (error) {   // 请求失败以后的回调函数
          console.log(error);
        });
    
    	
    	// b'firstName=Fred&lastName=Flintstone'
    
    

    json

    # json 是一个数据格式.
    # json数据对象类似于JavaScript中的对象,但是它的键对应的值里面是没有函数方法的,值可以是普通变量,不支持undefined,值还可以是数组或者json对象。
    
    
    // json数据的对象格式,json数据格式,是没有方法的,只有属性:
    {
        "name":"tom",
        "age":18
    }
    
    // json数据的数组格式:
    ["tom",18,"programmer"]
    
    
    // 复杂的json格式数据可以包含对象和数组的写法。
    {
      "name":"小明",
      "age":200,
      "is_delete": false,
      "fav":["code","eat","swim","read"],
      "son":{
        "name":"小小明",
        "age":100,
        "lve":["code","eat"]
      }
    }
    
    // 数组结构也可以作为json传输数据。
    
    
    ## 总结:
        1. json文件的后缀是.json
        2. json文件一般保存一个单一的json数据
        3. json数据的属性不能是方法或者undefined,属性值只能:数值[整数,小数,布尔值]、字符串、json和数组
        4. json数据只使用双引号、每一个属性成员之间使用逗号隔开,并且最后一个成员没有逗号。
           {
              "name":"小明",
              "age":200,
              "fav":["code","eat","swim","read"],
              "son":{
                "name":"小小明",
                "age":100
              }
            }
    
    

    ajax

    # ajax,一般中文称之为:"阿贾克斯",是英文 “Async Javascript And Xml”的简写,译作:异步js和xml数据传输数据。
    
    # ajax的作用: ajax可以让js代替浏览器向后端程序发送http请求,与后端通信,在用户不知道的情况下操作数据和信息,从而实现页面局部刷新数据/无刷新更新数据。
    
    # 所以开发中ajax是很常用的技术,主要用于操作后端提供的`数据接口`,从而实现网站的`前后端分离`。
    
    # ajax技术的原理是实例化js的XMLHttpRequest对象,使用此对象提供的内置方法就可以与后端进行数据通信。
    
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="js/jquery-1.12.4.js"></script>
        <script>
        $(function(){
            $("#btn").on("click",function(){
                $.ajax({
                    // 后端程序的url地址
                    url: 'http://wthrcdn.etouch.cn/weather_mini',
                    // 也可以使用method,提交数据的方式,默认是'GET',常用的还有'POST'
                    type: 'get', 
                    dataType: 'json',  // 返回的数据格式,常用的有是'json','html',"jsonp"
                    data:{ // 设置发送给服务器的数据,如果是get请求,也可以写在url地址的?后面
                        "city":'北京'
                    }
                })
                .done(function(resp) {     // 请求成功以后的操作
                    console.log(resp);
                })
                .fail(function(error) {    // 请求失败以后的操作
                    console.log(error);
                });
            });
        })
        </script>
    </head>
    <body>
    <button id="btn">点击获取数据</button>
    </body>
    </html>
    
    

    同源策略***

    # 同源策略,是浏览器为了保护用户信息安全的一种安全机制。所谓的同源就是指代通信的两个地址(例如服务端接口地址与浏览器客户端页面地址)之间比较,是否协议、域名(IP)和端口相同。不同源的客户端脚本[javascript]在没有明确授权的情况下,没有权限读写对方信息。
    
    # ajax本质上还是javascript,是运行在浏览器中的脚本语言,所以会被受到浏览器的同源策略所限制。
    
    
    #总结:
    	协议 ip 端口 都要一致才不会存在同源策略安全.
    
    

    ajax跨域(跨源)方案之CORS

    ajax跨域(跨源)方案:后端授权[CORS],jsonp,服务端代理
    
          CORS是一个W3C标准,全称是"跨域资源共享",它允许浏览器向跨源的后端服务器发出ajax请求,从而克服了AJAX只能同源使用的限制。
    
         实现CORS主要依靠<mark>后端服务器中响应数据中设置响应头信息Access-Control-Allow-Origin返回</mark>的。
    
    
    // 在响应行信息里面设置以下内容:
    Access-Control-Allow-Origin: ajax所在的域名地址
    
    Access-Control-Allow-Origin: www.oldboy.cn  # 表示只允许www.oldboy.cn域名的客户端的ajax跨域访问
    
    // * 表示任意源,表示允许任意源下的客户端的ajax都可以访问当前服务端信息
    Access-Control-Allow-Origin: *
    
    
    ### 解决ajax只能同源访问数据接口的方式:
       1. CORS,跨域资源共享,在服务端的响应行中设置:
          Access-Control-Allow-Origin: 允许访问的域名地址
       2. jsonp
       3. 是否服务端代理
          思路:通过python来请求对应的服务器接口,获取到数据以后,
    
    

    axios解决跨域

    # setting配置文件 更改host请求数据域名
    
    
  • 相关阅读:
    random(1)
    django(1)
    python复习
    bootstrap(1)
    jquery(2)
    Jquery(3)
    day17 正则表达式 re模块
    文字笔记
    MATLAB之数学建模:深圳市生活垃圾处理社会总成本分析
    MATLAB之折线图、柱状图、饼图以及常用绘图技巧
  • 原文地址:https://www.cnblogs.com/dengz/p/11985098.html
Copyright © 2011-2022 走看看