Vue.js总结 [2017.6.5]

<head>

  <script src="https://unpkg.com/vue/dist/vue.js"></script>

</head>

 

<body>

  //所有 v- 都为指令,表示它们是Vue的特殊属性

  <span v-bind:title="xxx"></span>    v-bind   【控制属性】

  <span :class="{red:isRed}"></span> 简写 【判断class是否为isRed】

  <span :class="[classA,classB]"></span> 【数组,两个class,可赋值】

  <span :class="[classA,{classB:isB,classC:isC}]"></span>  【数组,第一个为字符串可赋值,第二个判断class是否展现不可赋值】

  <span v-if="seen"></span>    v-if 条件与循环【如果seen为true则显示】

  <span v-show="seen"></span>  【如果seen为true则显示】

  <span v-for="todo in todos">{{todo.text}}</span>   v-for【绑定数组的数据来渲染一个项目列表】

  <span v-on:click="reverseMessage"></span>   v-on【绑定一个事件监听器】[在methods使用]

  <span @click="reverseMessage"></span>   [在methods使用]

  //渲染数据  

  <p v-text="a"></p>

  <p v-html="a"></p>

  {{}}

</body>

<script>

  var vm = new Vue(){}  //创建Vue

  //v-bind:tltle="message"

    var vm = new Vue(){

      el:'标签名/id/className [例如:#id]',

      data:{

       message:'页面加载中'

      }

    }

  //v-if="seen"

    var vm = new Vue(){

      el:'标签名/id/className [例如:#id]',

      data:{

       seen:true

      }

     }

  //v-for="todo in todos"

    var vm = new Vue(){

      el:'标签名/id/className [例如:#id]',

      data:{

       todos:[

        {text:"HTML"},

        {text:"css"},

        {text:"java"}

        ]

      }

     }

    vm.todos.push({text:'新项目'})

  //v-on:click="reverseMessage"

  //vue.js组件的重要选项  

  data vue对象里用到的所有数据  model

  methods用于页面绑定的方法

  watch数据监听,数据改变时可用

  components:{}注册组件

  item 数组

   

//如果想控制class的显示隐藏的话

<div id="app">
    <li  v-bind:class="{show:item.isFinished}">
	{{item.label}}
    </li>
</div>

<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					items:[
						{
							label:'coding',
							isFinished:false
						},
						{
							label:'walking',
							isFinished:true
						}				
					]
				}
			}
		})
</script>

 

//如果想添加多个class,并给其赋值

<div id="app">
    <li  v-bind:class="[class1,class2]">
	{{item.label}}
    </li>
</div>

<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					class1:'nihao',
					class2:"lalala"
				}
			}
		})
</script>

 

//如果想添加一个class

<div id="app">
    <li  v-bind:class="[class12]">
	{{item.label}}
    </li>
</div>

<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					class12:'nihao'
				}
			}
		})
</script>

 

//class的切换
<div id="app">
	<ul class="ul">
		<li v-for="item in items" v-bind:class="{finished:item.isFinished}" v-on:click="toggleFinish(item)">
			{{item.label}}
		</li>
				
	</ul>
</div>

<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					items:[
						{
							label:'coding',
							isFinished:false
						},
						{
							label:'walking',
							isFinished:true
						}				
					]
				}
			},
			methods:{
				toggleFinish:function(item){
					item.isFinished = !item.isFinished
				}
			}
		})
	</script>

 

//input select ,textarea 输入字符将其与其他标签绑定
<body>
    <div id="app">
		<input v-model='newModel' v-on:keyup.enter='addNew'/>
    </div>
</body>
<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					newModel:''
				}
			},
			methods:{
				addNew:function(){
					console.log(this.newModel)
					this.newModel=''
				}
			}
			
			
		})
</script>

 

//在input中输入字符添加到li中
<body>
    <div id="app">
		<input v-model='newItem' v-on:keyup.enter="addNew" />
			<ul class="ul">
				<li v-for="item in items" v-bind:class="{finished:item.isFinished}" v-on:click="toggleFinish(item)">
					{{item.label}}
				</li>
					
			</ul>
		</div>
		
	</body>
	<script>
		var i = new Vue({
			el:'#app',
			data:function(){
				return{
					items:[
						{
							label:'coding',
							isFinished:true
						},
						{
							label:'walking',
							isFinished:true
						}				
					],
					newItem:''
				}
			},
			methods:{
				addNew:function(){
					this.items.push({
						label:this.newItem,
						isFinished:false
					})
					this.newItem = ''
				}
			}
			
			
		})
	</script>

 自定义事件

vue实例实现了一个自定义事件接口,用于在组件树中通信,在这个事件系统独立于原生Dom事件,用法也不同。

每个Vue实例都是一个事件触发器:

1.使用$on()监听事件;

2.使用$emit()在它上面触发事件

3.使用$dispatch()派发事件,事件沿着父链冒泡;

4.使用$boradcast()广播事件,事件向下传导给所有的后代

 

</script>

posted @ 2017-06-05 18:03  小短腿奔跑吧  阅读(262)  评论(0编辑  收藏  举报