Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程

这篇具有很好参考价值的文章主要介绍了Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

学习链接:尚硅谷Vue2.0+Vue3.0全套教程丨vuejs从入门到精通,本文对应p79-p95,博客参考尚硅谷公开笔记,补充记录实操。

📚Vue 中的自定义事件

🐇使用方法

  • 区别于JS里的内置事件。

  • 一种组件间通信的方式,适用于:子组件 ===> 父组件

  • 使用场景:A是父组件,B是子组件,B想给A传数据,那么就要在A中给B绑定自定义事件(事件的回调在A中)。

  • 绑定自定义事件:

    • 第一种方式,在父组件中:<Demo @atguigu="test"/><Demo v-on:atguigu="test"/>
    • 第二种方式,在父组件中:
      <Demo ref="demo"/>
      ......
      mounted(){
         this.$refs.xxx.$on('atguigu',this.test)
      }
      
  • 若想让自定义事件只能触发一次,可以使用once修饰符,或$once方法。

  • 触发自定义事件:this.$emit('atguigu',数据)

  • 解绑自定义事件this.$off('atguigu'),多个一起解绑套在一个数组里。this.$off() ,解绑所有的自定义事件。

  • 组件上也可以绑定原生DOM事件,需要使用native修饰符。

  • 注意:通过this.$refs.xxx.$on('atguigu',回调)绑定自定义事件时,回调要么配置在methods中要么用箭头函数,否则this指向会出问题!


🐇案例练习

  • 案例实现,实操见真知😄
  • Student-Test.vue
    <template>
    	<div class="student">
    		<h2>学生姓名:{{name}}</h2>
    		<h2>学生性别:{{sex}}</h2>
    		<h2>当前求和为:{{number}}</h2>
    		<button @click="add">点我number++</button>
    		<button @click="sendStudentlName">把学生名给App</button>
    		<button @click="unbind">解绑atguigu事件</button>
    		<button @click="death">销毁当前Student组件的实例(vc)</button>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'Student-Test',
    		data() {
    			return {
    				name:'右一',
    				sex:'女',
    				number:0
    			}
    		},
    		methods: {
    			add(){
    				console.log('add回调被调用了')
    				this.number++
    			},
    			sendStudentlName(){
    				//触发Student组件实例身上的atguigu事件
    				this.$emit('atguigu',this.name,666,888,900)
    				// this.$emit('demo')
    				// this.$emit('click')
    			},
    			unbind(){
    				this.$off('atguigu') //解绑一个自定义事件
    				console.log('解绑了')
    				// this.$off(['atguigu','demo']) //解绑多个自定义事件(写在一个数组里)
    				// this.$off() //解绑所有的自定义事件
    			},
    			death(){
    				//销毁了当前Student组件的实例,销毁后所有Student实例的自定义事件全都不奏效。
    				//和视频里展示的不一样,现在销毁后原生num++也不奏效了,不论是console还是响应式。
    				this.$destroy() 
    				console.log('销毁了')
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	.student{
    		background-color: pink;
    		padding: 5px;
    		margin-top: 30px;
    	}
    </style>
    
  • School-Test.vue
    <template>
    	<div class="school">
    		<h2>学校名称:{{name}}</h2>
    		<h2>学校地址:{{address}}</h2>
    		<button @click="sendSchoolName">把学校名给App</button>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'School-Test',
    		props:['getSchoolName'],
    		data() {
    			return {
    				name:'哔哩哔哩大学',
    				address:'bilibili',
    			}
    		},
    		methods: {
    			sendSchoolName(){
    				this.getSchoolName(this.name)
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	.school{
    		background-color: skyblue;
    		padding: 5px;
    	}
    </style>
    
  • App.vue
    <template>
    	<div class="app">
    		<h1>{{msg}}学生姓名是:{{studentName}}</h1>
    
    		<!-- 通过父组件给子组件传递函数类型的props实现:子给父传递数据 -->
    		<School :getSchoolName="getSchoolName"/>
    
    		<!-- 通过父组件给子组件绑定一个自定义事件实现:子给父传递数据(第一种写法,使用@或v-on) -->
    		<!-- <Student @atguigu="getStudentName" @demo="m1"/> -->
    
    		<!-- 通过父组件给子组件绑定一个自定义事件实现:子给父传递数据(第二种写法,使用ref) -->
    		<Student ref="student" @click.native="show"/>
    	</div>
    </template>
    
    <script>
    	import Student from './components/Student-Test'
    	import School from './components/School-Test'
    
    	export default {
    		name:'App',
    		components:{School,Student},
    		data() {
    			return {
    				msg:'你好啊!',
    				studentName:''
    			}
    		},
    		methods: {
    			getSchoolName(name){
    				console.log('App收到了学校名:',name)
    			},
    			getStudentName(name,...params){
    				console.log('App收到了学生名:',name,params)
    				this.studentName = name
    			},
    			m1(){
    				console.log('demo事件被触发了!')
    			},
    			show(){
    				alert(123)
    			}
    		},
    		mounted() {
    			this.$refs.student.$on('atguigu',this.getStudentName) //绑定自定义事件
    			// this.$refs.student.$once('atguigu',this.getStudentName) //绑定自定义事件(一次性)
    		},
    	}
    </script>
    
    <style scoped>
    	.app{
    		background-color: gray;
    		padding: 5px;
    	}
    </style>
    
  • num++
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • 发送学生名Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • 解绑
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • 解绑后学生名发不出去了
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • 销毁
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • num++可点击,但不奏效
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript

🐇TodoList案例优化

  • 所有涉及到子组件给父组件传输的:
    • 添加一个todo,addTodo
    • 底部全选,checkAllTodo
    • 清除已完成,clearAllTodo
    • addTodo为例,
      • 首先,在App.vue中把:addTodo="addTodo"改为@addTodo="addTodo"
      • 而后在UserHeader中把props去除(不用接收了)。
      • 功能实现处:
        // 通知APP组件去添加一个todo对象
        this.$emit('addTodo',todoObj)
        

📚全局事件总线

🐇使用方法

  1. 一种组件间通信的方式,适用于任意组件间通信

  2. 安装全局事件总线

    new Vue({
    	......
    	beforeCreate() {
    		Vue.prototype.$bus = this //安装全局事件总线,$bus就是当前应用的vm
    	},
        ......
    }) 
    
  3. 使用事件总线

    • 接收数据:A组件想接收数据,则在A组件中给$bus绑定自定义事件,事件的回调留在A组件自身

      methods(){
        demo(data){......}
      }
      ......
      mounted() {
        this.$bus.$on('xxxx',this.demo)
      }
      
    • 提供数据:this.$bus.$emit('xxxx',数据)

  4. 最好在beforeDestroy钩子中,用$off去解绑当前组件所用到的事件。


🐇案例练习

  • main.js:安装全局事件总线。
    //引入Vue
    import Vue from 'vue'
    //引入App
    import App from './App.vue'
    //关闭Vue的生产提示
    Vue.config.productionTip = false
    
    //创建vm
    new Vue({
    	el:'#app',
    	render: h => h(App),
    	beforeCreate() {
    		Vue.prototype.$bus = this //安装全局事件总线
    	},
    })
    
  • Student-Test.vue:提供数据。
    <template>
    	<div class="student">
    		<h2>学生姓名:{{name}}</h2>
    		<h2>学生性别:{{sex}}</h2>
    		<button @click="sendStudentName">把学生名给School组件</button>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'Student-Test',
    		data() {
    			return {
    				name:'youyi',
    				sex:'女',
    			}
    		},
    		methods: {
    			sendStudentName(){
    				this.$bus.$emit('hello',this.name)
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	.student{
    		background-color: pink;
    		padding: 5px;
    		margin-top: 30px;
    	}
    </style>
    
  • School-Test.vue:接收数据。
    <template>
    	<div class="school">
    		<h2>学校名称:{{name}}</h2>
    		<h2>学校地址:{{address}}</h2>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'School-Test',
    		data() {
    			return {
    				name:'哔哩哔哩大学',
    				address:'bilibili',
    			}
    		},
    		mounted() {
    			// console.log('School',this)
    			this.$bus.$on('hello',(data)=>{
    				console.log('我是School组件,收到了数据',data)
    			})
    		},
    		beforeDestroy() {
    			this.$bus.$off('hello')
    		},
    	}
    </script>
    
    <style scoped>
    	.school{
    		background-color: skyblue;
    		padding: 5px;
    	}
    </style>
    
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript

🐇TodoList案例优化

  • 把“爷孙”之间的改成全局事件总线:
    • 勾选一个todo,checkTodo
    • 删除一个todo,deleteTodo
    • 修改点:
      • 在main.js安装全局事件总线
        new Vue({
        	el:'#app',
        	render: h => h(App),
        	beforeCreate(){
        		Vue.prototype.$bus = this
        	}
        })
        
      • checkTododeleteTodo不用给List传了,List对应也不用接收了。同样的,List也不用给Item,后者也不收了。也就是之前的层级传递过程删掉。
      • 收数据的(App.vue)绑定事件总线。
        mounted(){
        	this.$bus.$on('checkTodo',this.checkTodo)
        	this.$bus.$on('deleteTodo',this.deleteTodo)
        },
        beforeDestroy(){
        	this.$bus.$off('checkTodo')
        	this.$bus.$off('deleteTodo')
        }
        
      • Item提供数据。
        methods:{
            // 勾选or取消勾选
            handleCheck(id){
                // 通知App组件将对应的todo对象的done值取反
                this.$bus.$emit('checkTodo',id)
            },
            // 删除
            handleDelete(id){
                if(confirm('确定删除吗?')){
                    // 通知App组件删除
                    this.$bus.$emit('deleteTodo',id)
                }
            }
        }
        

📚消息订阅与发布

🐇使用方法

  1. 一种组件间通信的方式,适用于任意组件间通信

  2. 使用步骤

    • 安装pubsub:npm i pubsub-js
    • 引入: import pubsub from 'pubsub-js'
    • 接收数据:A组件想接收数据,则在A组件中订阅消息,订阅的回调留在A组件自身
      methods(){
        demo(data){......}
      }
      ......
      mounted() {
        this.pid = pubsub.subscribe('xxx',this.demo) //订阅消息
      }
      
    1. 提供数据pubsub.publish('xxx',数据)

    2. 最好在beforeDestroy钩子中,用PubSub.unsubscribe(pid)取消订阅

🐇TodoList案例优化

⭐️把删除一个todo(deleteTodo)改成消息订阅与发布

  • 引入pubsub库(用到的vue都需要引入),import pubsub from 'pubsub-js'
  • App.vue需要数据,订阅消息。这里需要methods里deleteTodo(_,id)_占个位。
    mounted(){
    	this.$bus.$on('checkTodo',this.checkTodo)
    	this.pubId = pubsub.subscribe('deleteTodo',this.deleteTodo)
    },
    beforeDestroy(){
    	this.$bus.$off('checkTodo')
    	pubsub.unsubscribe(this.pubId)
    }
    
  • UserItem.vue提供数据。
    methods:{
        // 勾选or取消勾选
        handleCheck(id){
            // 通知App组件将对应的todo对象的done值取反
            this.$bus.$emit('checkTodo',id)
        },
        // 删除
        handleDelete(id){
            if(confirm('确定删除吗?')){
                // 通知App组件删除
                pubsub.publish('deleteTodo',id)
            }
        }
    }
    

⭐️添加编辑todo效果

  • UserItem.vue样式添加编辑按钮。
    Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
  • UserItem.vue
    <template>
        <li>
            <label>
                <input type="checkbox" :checked="fasong.done" @change="handleCheck(fasong.id)"/>
                <span v-show="!fasong.isEdit">{{fasong.title}}</span>
                <input 
                    type="text" 
                    v-show="fasong.isEdit" 
                    :value="fasong.title"
                    @blur="handleBlur(fasong,$event)"
                >
            </label>
            <button class="btn btn-danger" @click="handleDelete(fasong.id)">删除</button>
            <button v-show="!fasong.isEdit" class="btn btn-edit" @click="handleEdit(fasong)">编辑</button>
        </li>
    </template>
    
    <script>
        import pubsub from 'pubsub-js'
        export default {
            name:'UserItem',
            // 声明接收发送内容
            props:['fasong'],
            methods:{
                // 勾选or取消勾选
                handleCheck(id){
                    // 通知App组件将对应的todo对象的done值取反
                    this.$bus.$emit('checkTodo',id)
                },
                // 删除
                handleDelete(id){
                    if(confirm('确定删除吗?')){
                        // 通知App组件删除
                        pubsub.publish('deleteTodo',id)
                    }
                },
                //编辑
                handleEdit(fasong){
                    // 已经有了isEdit
                    if(fasong.hasOwnProperty.call('isEdit')){
                        fasong.isEdit = true
                    }else{
                        this.$set(fasong,'isEdit',true)
                    }
                },
                // 失去焦点回调(真正执行修改)
                handleBlur(fasong,e){
                    fasong.isEdit = false
                    this.$bus.$emit('updateTodo',fasong.id,e.target.value)
                }
            }
        }
    </script>
    
  • App.vue
    <template>
    	<div id="root">
    		<div class="todo-container">
    			<div class="todo-wrap">
    				<UserHeader @addTodo="addTodo"></UserHeader>
    				<UserList :todos="todos"></UserList>
    				<UserFooter :todos="todos" @checkAllTodo="checkAllTodo" @clearAllTodo="clearAllTodo"></UserFooter>
    			</div>
    		</div>
    	</div>
    
    </template>
    
    <!-- App.vue -->
    <script>
    	import pubsub from 'pubsub-js'
    	import UserHeader from './components/UserHeader.vue'
    	import UserList from './components/UserList'
    	import UserFooter from './components/UserFooter'
    	
    	export default {
    		name:'App',
    		components:{UserHeader,UserList,UserFooter},
    		data(){
                return{
                    todos:JSON.parse(localStorage.getItem('todos')) || []
                }
            },
    		methods:{
    			// 数据在哪,对数据的操作就在哪
    			// 添加一个todo
    			addTodo(todoObj){
    				this.todos.unshift(todoObj)
    			},
    			// 勾选or取消勾选一个todo
    			checkTodo(id){
    				this.todos.forEach((todo)=>{
    					if(todo.id === id) todo.done = !todo.done
    				})
    			},
    			// 修改一个todo
    			updateTodo(id,title){
    				this.todos.forEach((todo)=>{
    					if(todo.id === id) todo.title = title
    				})
    			},
    			// 删除一个todo
    			deleteTodo(_,id){
    				// this.todos = this.todos.filter((todo)=>{
    				// 	return todo.id !== id
    				// })
    				// 精简写法
    				this.todos = this.todos.filter(todo => todo.id != id)
    			},
    			// 全选or取消全选
    			checkAllTodo(done){
    				this.todos.forEach((todo)=>{
    					todo.done = done
    				})
    			},
    			// 清除所有已经完成的todo
    			clearAllTodo(){
    				this.todos = this.todos.filter((todo)=>{
    					return !todo.done
    				})
    			}
    		},
    		watch:{
    			todos:{
    				// 开启深度监视
    				deep:true,
    				handler(value){
    					localStorage.setItem('todos',JSON.stringify(value))
    				}
    			}
    		},
    		mounted(){
    			this.$bus.$on('checkTodo',this.checkTodo)
    			this.$bus.$on('updateTodo',this.updateTodo)
    			this.pubId = pubsub.subscribe('deleteTodo',this.deleteTodo)
    		},
    		beforeDestroy(){
    			this.$bus.$off('checkTodo')
    			this.$bus.$off('updateTodo')
    			pubsub.unsubscribe(this.pubId)
    		}
    	}
    </script>
    
    • 准备编辑
      Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
    • 正在编辑(按钮不显示)
      Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
    • 焦点移除,修改
      Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript

⭐️内容不为空限制

// 失去焦点回调(真正执行修改)
handleBlur(fasong,e){
    fasong.isEdit = false
    if(!e.target.value.trim()) return alert('输入不能为空')
    this.$bus.$emit('updateTodo',fasong.id,e.target.value)
}

Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript

⭐️点击编辑按钮自动获取焦点

this.$nextTick(function(){
   this.$refs.inputTitle.focus()
})
  • 🔥 nextTick
    • 语法:this.$nextTick(回调函数)
    • 作用:在下一次 DOM 更新结束后执行其指定的回调。
    • 什么时候用:当改变数据后,要基于更新后的新DOM进行某些操作时,要在nextTick所指定的回调函数中执行。

📚Vue封装的过度与动画

🐇使用方法

  1. 作用:在插入、更新或移除 DOM元素时,在合适的时候给元素添加样式类名。
  2. 写法
    • 准备好样式

      • 元素进入的样式:
        • v-enter:进入的起点
        • v-enter-active:进入过程中
        • v-enter-to:进入的终点
      • 元素离开的样式:
        • v-leave:离开的起点
        • v-leave-active:离开过程中
        • v-leave-to:离开的终点
          Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript
    • 使用<transition>包裹要过度的元素,并配置name属性:

      <transition name="hello">
      	<h1 v-show="isShow">你好啊!</h1>
      </transition>
      
    • 备注:若有多个元素需要过度,则需要使用:<transition-group>,且每个元素都要指定key值。

🐇案例练习

  • 过度效果

    <template>
    	<div>
    		<button @click="isShow = !isShow">显示/隐藏</button>
    		<transition name="hello" appear>
    			<h1 v-show="isShow">你好啊!</h1>
    		</transition>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'Final-Test',
    		data() {
    			return {
    				isShow:true
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	h1{
    		background-color: pink;
    	}
    
    	.hello-enter-active{
    		animation: atguigu 0.5s linear;
    	}
    
    	.hello-leave-active{
    		animation: atguigu 0.5s linear reverse;
    	}
    
    	@keyframes atguigu {
    		from{
    			transform: translateX(-100%);
    		}
    		to{
    			transform: translateX(0px);
    		}
    	}
    </style>
    
  • 多个元素过度

    <template>
    	<div>
    		<button @click="isShow = !isShow">显示/隐藏</button>
    		<transition-group name="hello" appear>
    			<h1 v-show="!isShow" key="1">你好啊!</h1>
    			<h1 v-show="isShow" key="2">尚硅谷!</h1>
    		</transition-group>
    	</div>
    </template>
    
    <script>
    	export default {
    		name:'Final-Test2',
    		data() {
    			return {
    				isShow:true
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	h1{
    		background-color: skyblue;
    	}
    	/* 进入的起点、离开的终点 */
    	.hello-enter,.hello-leave-to{
    		transform: translateX(-100%);
    	}
    	.hello-enter-active,.hello-leave-active{
    		transition: 0.5s linear;
    	}
    	/* 进入的终点、离开的起点 */
    	.hello-enter-to,.hello-leave{
    		transform: translateX(0);
    	}
    </style>
    
  • 集成第三方动画,animate.css官网

    <template>
    	<div>
    		<button @click="isShow = !isShow">显示/隐藏</button>
    		<transition-group 
    			appear
    			name="animate__animated animate__bounce" 
    			enter-active-class="animate__swing"
    			leave-active-class="animate__backOutUp"
    		>
    			<h1 v-show="!isShow" key="1">你好啊!</h1>
    			<h1 v-show="isShow" key="2">尚硅谷!</h1>
    		</transition-group>
    	</div>
    </template>
    
    <script>
    	// npm install animate.css
    	import 'animate.css'
    	export default {
    		name:'Final-Test3',
    		data() {
    			return {
    				isShow:true
    			}
    		},
    	}
    </script>
    
    <style scoped>
    	h1{
    		background-color: rgb(0, 255, 183);
    	}
    </style>
    

Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程,# 高级技术,web开发——前端,vue.js,javascript,ecmascript文章来源地址https://www.toymoban.com/news/detail-836485.html

🐇TodoList案例优化

  • 让每一个todo的添加和删除都很柔和
    • 法①:UserItem.vue的整个li加过度和动画
    • 法②:在UserList.vue添加(关注多组是transition-group)(以下代码实现方式)
  • 结构部分
    <template>
        <ul class="todo-main">
            <transition-group name="todo" appear>
                <UserItem 
                    v-for="todoObj in todos" 
                    :key="todoObj.id" 
                    :fasong="todoObj" 
                ></UserItem>
            </transition-group>
        </ul>
    </template>
    
  • 样式部分
    .todo-enter-active{
        animation: atguigu 0.5s linear;
     }
    
     .todo-leave-active{
         animation: atguigu 0.5s linear reverse;
     }
    
     @keyframes atguigu {
         from{
             transform: translateX(100%);
         }
         to{
             transform: translateX(0px);
         }
     }
    

到了这里,关于Vue | (三)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 创建一个vue2的脚手架项目(超详细)

    0.前言 在用npm安装vue脚手架之前需要安装node,前面博客有详细安装过程,请读者安装node之后再进行脚手架的安装 1 npm vue2的安装脚手架 2.创建vue2脚手架项目 3.开启服务器 4.在浏览器中输入端口地址 5.项目目录介绍

    2024年02月11日
    浏览(71)
  • 【前端】Vue2 脚手架模块化开发 -快速入门

    🎄欢迎来到@边境矢梦°的csdn博文🎄  🎄本文主要梳理Vue2 脚手架模块化开发 🎄 🌈我是边境矢梦°,一个正在为秋招和算法竞赛做准备的学生🌈 🎆喜欢的朋友可以关注一下 🫰🫰🫰 ,下次更新不迷路🎆 Ps: 月亮越亮说明知识点越重要 (重要性或者难度越大)🌑🌒🌓🌔🌕

    2024年02月10日
    浏览(82)
  • Vue2学习之第三章——Vue CLI脚手架

    文档:https://cli.vuejs.org/zh/ 具体步骤 第一步(仅第一次执行):全局安装@vue/cli。 npm install -g @vue/cli 第二步:切换到你要创建项目的目录,然后使用命令创建项目 vue create xxxx 第三步:启动项目 npm run serve 备注: 如出现下载缓慢请配置 npm 淘宝镜像:npm config set registry https:/

    2024年01月19日
    浏览(202)
  • Vue3脚手架笔记

    Vue模板语法有2大类 : 1.插值语法: 功能:用于解析标签体内容。 写法:{{xxx}},xxx是js表达式,且可以直接读取到data中的所有属性。 ** 2.指令语法:** 功能:用于解析标签(包括:标签属性、标签体内容、绑定事件…)。 举例:v-bind:href=“xxx” 或 简写为 :href=“xxx”,xxx同

    2024年01月24日
    浏览(52)
  • Vue2-配置脚手架、分析脚手架、render函数、ref属性、props配置项、mixin配置项、scoped样式、插件

    🥔:总有一段付出了没有回报的日子 是在扎根 更多Vue知识请点击——Vue.js Vue CLI(Vue Command Line Interface)Vue脚手架,Vue官方提供的标准化开发工具(开发平台) 安装node.js——可以查看此教程 第一步:输入命令npm config set registry=http://registry.npm.taobao.org 配置镜像站,全局安装

    2024年02月12日
    浏览(68)
  • vue3笔记-脚手架篇

    第一章 基础篇 vue2与vue3的一些区别 响应式系统: Vue 2 使用 Object.defineProperty 进行响应式数据的劫持和监听,它对数据监听是一项项的进行监听,因此,当新增属性发生变化时,它无法监测到,并且响应性能不是很好。 Vue 3 使用 Proxy 来实现响应式系统,它用一个中间代理来管

    2024年02月16日
    浏览(43)
  • 初识esbuild、构建vue3脚手架

    esbuild 非常快速的 web 打包器,使用 go 语言编写。 📦 特点: 无需缓存也能很快速的编译打包。 内置 js、css、ts、jsx 类型文件编译。 支持 es6 和 commonjs 模块。 可以编译打包成 esm 模块和 common JS 模块 tree shaking 摇树优化、优化资源大小、source-map 代码映射 启动本地服务,在监听

    2024年02月01日
    浏览(43)
  • Vue3 脚手架搭建项目详细过程

    如果之前安装了2.0的脚手架,要先卸载掉,输入:npm uninstall vue-cli -g 进行全局卸载 然后重新安装:npm install @vue/cli -g 由于 git bash 来执行命令的时候无法使用键盘上下键来进行选项选择,所以我们要使用  cmd / powershell,这里使用 cmd 1.vue create + 项目名称  2.模板选择,通过键

    2024年02月06日
    浏览(75)
  • 【Vue2+3入门到实战】(17)VUE之VueCli脚手架自定认创建项目、ESlint代码规范与修复、 ESlint自动修正插件的使用 详细示例

    VueCli脚手架自定认创建项目 ESlint代码规范与修复 ESlint自动修正插件 1.安装脚手架 (已安装) 2.创建项目 选项 手动选择功能 选择vue的版本 是否使用history模式 选择css预处理 选择eslint的风格 (eslint 代码规范的检验工具,检验代码是否符合规范) 比如:const age = 18; = 报错!多加

    2024年02月03日
    浏览(58)
  • Vue学习计划-Vue2--VueCLi(二)vuecli脚手架创建的项目内部主要文件分析

    1. 补充: 什么叫单文件组件? 一个文件中只有一个组件 vue-cli 创建的项目中, .vue 的文件都是单文件组件,例如 App.vue 2. 进入分析 1. package.json : 项目依赖配置文件: 如图,我们说主要的属性: name : 项目的名称 version : 项目版本 scripts : 脚本入口 serve : 启动项目命令 build :

    2024年02月04日
    浏览(77)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包