vue不用脚手架封装组件的方法

第一中:

	创建一个vue实例
		<div id="app">
		// mycom2 就是引入封装的公共组件			
		<mycom2></mycom2>
	</div>
	
	<!-- 定义再外面的 vue 模板组件而且是一个公共的组件 -->
	<template id="tmp1">
		<div>
			<h1>我是一个公共组件</h1>
		</div>
	</template>
	
		var app = new Vue({
			el: '#app',
			data: {},
			method: {},
		
		});
		//开始封装一个公共的组件
		Vue.component('mycom2', {
			template: '#tmp1'
		})

第二种封装一个私有的组件

	<!-- 这是一个私有的组件只能在 div id='SY'的里面才能被访问 -->
	<div id="SY">
		<div>
			<login></login>
		</div>
	</div>

		<template id="tmp12">
		<div>
			<h1>这是一个私有的组件只能在 div id='SY'的里面才能被访问</h1>
		</div>
		</template>	

	var SY = new Vue({
			el: '#SY',
			data: {},
			method: {},
			components: {
				// login 是组件名
				login:{
					template:'#tmp12'
				}
			}
		})

组件里封装 data 和方法
组件中的 data 有点不一样,实例中的 data 可以是一个对象 但是组件中的 data 必须是一个 方法 function 还必须在 function 方法中 return 返回一个对象

		<div id="app">
		//使用封装的组件
			<mycom1></mycom1>
		</div>
		
		//封装组件
			<template id="zujian">
				<div>
					<h1>{{msg}}</h1>
					<button type="button" @click="dianji">点我加1</button>
				</div>
			</template>
		var app = new Vue({
			el: "#app",
			data: {},
			methods: {}
		})

		//封装的组件
		Vue.component('mycom1', {
			template: '#zujian',
			data: function() {
				return {
					msg:'1'
				}
				
			},
			methods:{
				dianji(){
					this.msg ++
				}
			}
		})