zoukankan      html  css  js  c++  java
  • vue01-上

    ------------------------VUE-------------------------------------------------

    	官网:https://cn.vuejs.org
    	API:https://cn.vuejs.org/v2/api/
    
    	小 -> 大
    	封装(函数)->多个封装(文件)==库||框架
    					↓				↓
    				   插件 				插件
    
    				   模块(文件)  分类(目录)->包
    	框架:改变了编码思想   VUE: 数据驱动,一切都是数据,面向数据
    		面向  事件
    		面向  对象
    		面向  数据
    	库:  工具本身不改变编码的方式
    		jquery -> dom		事件驱动
    
    	MVC:html页面里面会出现<%=后台属性%>  {$后台属性$} {{后台属性}} mustache
    		一个思想、是后端产物,是为了前后端分离
    		1. 后台 java(jsp+html)  php(php+html+js)  nodejs(nodejs+ejs)
    		2. 前台 (html+css+js)
    		3. 编辑 (拿着后台给他开发的后台管理页面xxx.com:8008/admin.php)
    		4. 设计
    
    	前端MVC(分离js):   数据、表现、业务分离
    		model		M  数据  ajax/jsonp/数据解析  可以复用
    			| xx.js
    			...
    		view	    V  视图表现层 展示数据、创建元素,变色,运动 可以复用
    			...
    		control		C  控制层(串业务,事件驱动)  一般不复用
    			...
    
    		function readBaidu(str,callback){..拿着需求str,求数据,调用回调带数据出去.}
    		function writeLi(data,callback){...拿着数据写页面}
    		window.onload=function(){
    			oBtn.onclick=function(){
    				readBaidu('xxx',function(res){
    					writeLi(res);
    					winObj.close()
    				})
    			}
    		}
    	VUE: 是个M V VM框架
    		MVC:衍生出很多变体  MVP MVVM MV*
    		mv  vm~C
    		MVVM M  <-> VM <-> V
    
    	基本使用:
    		new出来一个Vue的实例,传一堆配置参数,控制一片html
    
    		VM:		响应系统 - > vDOM做标记 ->一个循环周期结束后->操作DOM
    			new Vue   返回  VM
    			new Vue({
    				el:'选择器'  要控制的那片html代码
    				data:{key:value}数据
    				methods:{fnName:fn} 方法
    			})
    		M:	初始化数据
    			data 选项   number/string/boolean/array/json/undefined/null
    		V:  数据绑定
    			{{数据名}}	模板 mustche  插值表达式
    			v-text="数据名"		vue特有的属性(指令)
    			v-html="strong"		非转义输出
    			v-for="(val,index) in 数据"		val值  index索引	变量数组、对象
    				key="bmw"  指定key 是个bmw字符 vue是认得 修改VDom的key值
    				:key="item.id"  指定key 是数据id(唯一性) 修改VDom的key值
    			v-bind:html属性="数据"	普通的html属性绑定数据
    				:html属性="数据"  简写   title/src/url/.....
    			事件:
    				v-on:事件名="方法"
    
    >vue基本使用
    1、data专门放数据(M)
    实例通过控制el元素来控制body页面其中$叫实例系统属性或方法,不带的是自定义的实例属性。
    this指向实例,即可以通过this找到实例内的内容。
    响应式渲染,可是实时更改内容
    (在控制台打印vm.title='')
    
    <script src="./js/vue.js"></script>
    或者 <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js"></script>
    
    <body>
      <!-- V -->
      <div id="app">
        <!-- mustach语法 -->
        <h3>{{ title }}</h3>
        <p>{{ dp }}</p>
        <p>{{title}}</p>
      </div>
    
      <script>
        let vm = new Vue({
          // 选项
          // el:'选择器',
          el:'#app',
          data:{//M
            title:'标题',
            dp:'段落'
          }
        });
      </script>
      
    </body>
    

    m层的数据类型

    2、m层数据类型在渲染时有什么影响
    ①undefined到了页面不显示
    	②arr和json都转字符串
    	③布尔仍然是布尔值
    	④数值仍为数值
    
        <body>
    
      <!-- V -->
      <div id="app">
        <!-- mustach语法 -->
    
        <div>{{ num }}</div>
        <div>{{ arr }}</div>
        <div>{{ json }}</div>
        <div>{{ un }}</div>
        <div>{{ nu }}</div>
        <div>/{{ str }}/</div>
        <div>{{ bl }}</div>
    
        <hr>
    
        <div>/{{str2}}/</div>
    
      </div>
    
      <script>
        let vm = new Vue({
          // 选项
          // el:'选择器',
          el:'#app',
          data:{//M   初始化数据的地方
            title:'标题',
            num:110,
            arr:['aa','bb','cc'], //[ "aa", "bb", "cc" ]
            json:{a:1,b:2},       //{“a”:1,“b”:2}
            un:undefined,
            nu:null,
            str:'',
            bl:true,
            str2:'   '            //  /  /
          }
        });
        
      </script>
      
    </body>
    

    数据绑定

    3、数据绑定的形式
    ①指令:特殊的html自定义属性
    <div v-text='txt'></div>
    ②mustach
    {{ }}
    ③属性绑定1:html的属性值动态化
    例子:<img :src="src">
    ④属性绑定2属性名动态化
      <!-- V -->
      <div id="app">
        
        <h3>数据绑定的形式</h3>
    
        <h4>mustach:出现在开始和接受标签之间</h4>
        <div>{{ title }}</div>
    
        <hr>
    
        <h4>指令: 特殊的html自定义属性</h4>
        <!-- <div v-text="数据/实例属性"></div> -->
        <div v-text="txt"></div>
    
        <hr>
    
        <h4>属性绑定: html的属性值动态化</h4>
        <img :src="src" alt="">
    
        <h4>属性绑定2: 属性名动态化</h4>
        <img src="https://cn.vuejs.org/images/logo.png" v-bind:[propimg]="val1">
    
    
    
      </div>
    
      <script>
        let vm = new Vue({
          // 选项
          // el:'选择器',
          el:'#app',
          data:{//M   初始化数据的地方
            title:'标题',
            txt:'沙发斯蒂芬',
            src: 'https://cn.vuejs.org/images/logo.png',
            propimg: 'title',
            val1:'呵呵哒'
          }
        });
        
      </script>
      
    </body>
    

    列表渲染

    <body>
    
      <!-- V -->
      <div id="app">
        
        <h3>列表渲染</h3>
        <!-- 指令:里面可以给语句 -->
        <ul>
          <!-- <li v-for="val in arr">{{ val }}</li> -->
          <li v-for="val of arr">{{ val }}</li>
        </ul>
    
        <hr>
        
        <ul>
          <li v-for="item of arr2">
            <!-- 插值表达式 -->
            <p>姓名: {{ item.name }}</p>
            <p>地址: {{ item.address}}</p>
          </li>
        </ul>
    
        <hr>
    
        <ul>
          <li v-for="item of arr3">
            {{item.name}}/{{item.address}}
            <ul>
              <li v-for="item of item.children">
                {{item.name}}/{{item.address}}
              </li>
            </ul>
          </li>
        </ul>
    
      </div>
    
      <script>
        let vm = new Vue({
          // 选项
          // el:'选择器',
          el:'#app',
          data:{//M   初始化数据的地方
            arr:['aa','bb','cc'],
            arr2:[
              {id:1,name:'alex',address:'外滩18号'},
              {id:2,name:'alex2',address:'外滩1号'},
              {id:4,name:'alex3'},
            ],
            arr3:[
              {id:1,name:'alex',address:'外滩18号',children:[
                {id:1,name:'ooo',address:'霞飞路1号'},
                {id:1,name:'ooo2',address:'霞飞路11号'},
              ]},
              {id:2,name:'alex2',address:'外滩1号'},
              {id:4,name:'alex3'},
            ]
          
          }
        });
        
      </script>
      
    </body>
    

    绑定事件

    
      <!-- V -->
      <div id="app">
        
        <h4>事件绑定</h4>
    
        <div>{{num}}</div>
        <div v-show="bl">box</div>
    
        <!-- <input type="button" value="按钮" v-on:原生js事件名="函数"> -->
        <!-- <input type="button" value="按钮" v-on:touchstart="函数"> -->
        <!-- <input type="button" value="按钮" v-on:click="show1"> -->
        
        <!-- 简写 -->
        <!-- <input type="button" value="按钮" @原生js事件名="函数"> -->
        <input type="button" value="按钮" @click="show1">
        
    
      </div>
    
      <script>
        let vm = new Vue({
          // 选项
          // el:'选择器',
          el:'#app',
          data:{//M   初始化数据的地方
            num:110,
            bl: true
          },
          methods:{
            show1:function(){
              console.log(this)
              this.num=119+Math.random()
              this.bl=!this.bl
            }
          }
        });
        
      </script>
      
    </body>```
  • 相关阅读:
    【JavaScript】underscore
    【JavaScript】jQuery
    【JavaScript】浏览器
    【JavaScript】对象
    【JavaScript】函数
    【JavaScript】快速入门
    【python】异步IO
    【python】web开发
    【python】TCP/IP编程
    【python】常用第三方模块
  • 原文地址:https://www.cnblogs.com/sansancn/p/11039728.html
Copyright © 2011-2022 走看看