Vue的脚手架

news2025/1/9 5:51:35

脚手架配置

脚手架文档:Vue CLI

npm config set registry https://registry.npm.taobao.org

vue.config.js配置选项:

配置参考 | Vue CLI

ref选项

ref和id类似,给标签打标识。

document.getElementById('btn');

this.$ref.btn;

父子组件间通信

App.vue 加上冒号之后,18就成了一个表达式。 传递到Student中,就可以进行运算了。

<Student name="李四" age="18"/>
<Student name="李四" :age="18"/>  

Student.vue,接受的数据,相当于跑到了VC中的data里边。

props:['name','age']
props:{
    name:String,
    age:Number,
    sex:String
}
props:{
    name:{
        type:String,
        required:true,
        default:''
    }
}

props收到的属性,是不建议修改的,控制台会报错的。

data(){
    return{
        myAge:this.age
    }
}

但是将收到的属性值,赋值到新的字段中,是可以支持修改的。

引入混合js[复用配置]

mixin.js
export const hunhe = {
    methods:{
        showName(){
            //....
        }
    },
    mounted(){
        //....
    }
}

引入

import {hunhe} from '../mixin'
export default{
    name:'Student',
    data(){
        return{
        
        }
    },
    mixins:[hunhe],
}

全局混合,不建议用

import {hunhe,hunhe2} from './mixin'
Vue.mixin(hunhe)

插件plugins

plugins.js
export default{
    install(Vue){
        console.log('aaa');
        Vue.filter(...)
    }
}
main.js 在new Vue({})上边引入
import plugins from './plugins'
Vue.use(plugins)

scoped作用域

<style lang="less" scoped>
....
</style>

查看npm库版本

npm view webpack versions

npm i less-loader@7

子传父组件通信-v1

App.vue
methods:{
	receive(x){
		
	}
}
<Myheader :receive="receive"/>
//==============================================================
MyHeader.vue
props:['receive'],
methods:{
	add(e){
		this.reveive(e.target.value);
	}
}

统计数量

computed:{
	doneTotal(){
		let i = 0;
		this.todos.forEach((todo)=>{
			if(todo.done) i++;
		})
		return i;
	}
}
const x = this.todus.reduce((pre,current)=>{
	return pre+(current.todo ? 1: 0);
},0); //0是传入的初始值 {}里边的逻辑,数组有多少个,就调用多少次  
第二次调用时,pre就是第一次调用函数的返回值
current就是每一个todo项
x就是计算todo项为true的统计
computed:{
	doneTotal(){
		return this.todos.reduce((pre,todo)=>pre+(todo.done?1:0),0);
	}
}

浏览器的本地存储

localstorage也可以用在移动端开发中

**组件的自定义事件通信**

1、通过父组件给子组件传递函数类型的props实现,子给父传递数据

2、绑定自定义事件传递给父组件

//自定义事件,给Student所在的vc绑定事件
App.vue
<Student v-on:pshdhx="demo"/> 
methods:{
	demo(name){
		console.log('demo被调用了',name)
	}
}
Student.vue
<button @click="sendStudentName">把学生名传递给app</button>
methods:{
	sendStudentName(){
		this.$emit('pshdhx',this.name) //触发Student组件实例的pshdhx事件
	}
}

3、使用ref来替换

//使用ref来替换  <Student v-on:pshdhx="demo"/>  <Student @pshdhx.once="demo"/>
App.vue
<Student ref="student"/> 
methods:{
	getStudentName(name,...params){ //params是一个数组
		console.log('App.vue收到了Student.vue传递过来的name值',name,params);
	}
}
mounted:{
	this.$refs.student.$on('pshdhx',this.getStudentName);
	this.$refs.student.$once('pshdhx',this.getStudentName);
}

解绑自定义事件

//方法区域
unbind(){
	this.$off('pshdhx'); //只适用于解绑一个
	this.$off(['pshdhx','demo2']); //用数组来解绑多个自定义事件
	this.$off();//解绑所有
}

箭头函数没有自己的this,所以就往外找。

自定义组件要想使用Vue事件

<Student @click.native="showInfo"/>
//如果不加.native,它就是一个自定义事件。

全局事件总线

任意组件之间的通信。

傀儡VueComponent,就是x

//App.vue
const Demo = Vue.extend({})
const d = new Demo();
Vue.prototype.x = d;

//School.vue
mounted(){
	this.x.$on('hello',(data)=>{
		console.log('我是school组件,收到了数据',data);
	})
}
//Student.vue
methods:{
	sendStudentName(){
		this.x.$emit('hello',666);
	}
}

构建傀儡组件2 ,就是x

new Vue({
	el:'#app',
	render:h=>h(App),
	beforeCreate(){
		Vue.prototype.x = this
	}
})

x就是$bus了。

$bus很累了,所以销毁组件的时候,就要关闭

beforeDestory(){
	this.$bus.off('hello');
}

消息订阅与发布

npm i pubsub-js

School.vue
import pubsub from 'pubsub-js'
mounted:{
	this.pubid = pubsub.subscribe('hello',function(name,data){
		console.log('有人发布了hello消息,hello的回调执行了',data)
	})
}
Student.vue
import pubsub from 'pubsub-js'
methods:{
	sendStudentName(){
		pubsub.publish('hello',666);
	}
}

取消订阅,订阅之后,返回了一个id,需要销毁。

beforeDestory(){
	pubsub.unsubscribe(this.pubid);
}

判断对象有没有这个属性

todo.hasOwnProperty('isEdit')

$nextTick

点击编辑按钮,input获取焦点:

<input ref="inputTitle"/>
this.$ref.inputTitle.focus(); settimeout
this.$nextTick(function(){
	//会在dom节点更新之后,才会触发
})

动画效果

<template>
    <div>
        <button @click="isShow = !isShow">显示/隐藏</button>
<!--        <transition name="test" :appear="true"> 刷新时,也能有动画效果 -->
        <transition name="test" appear>
            <h1 v-show="isShow" class="come">你好呀</h1>
        </transition>
    </div>
</template>

<script>
    export default {
        // eslint-disable-next-line vue/multi-word-component-names
        name: "Test",
        data(){
            return{
                isShow:true
            }
        }
    }
</script>

<style scoped>

    /*借助动画效果去实现过度*/

    h1{
        background-color: aqua;
    }
    /*入场动画 名称固定 配合transition 使用*/
    /*.v-enter-active{*/
    .test-enter-active{
        animation: pshdhx 1s ;
    }

    /*离场动画,名称固定*/
    /*.v-leave-active{*/
    .test-leave-active{
        animation: pshdhx 1s reverse;
    }

    /*定义动画*/
    @keyframes pshdhx {
        from{
            transform: translateX(-100%);
        }
        to{
            transform: translateX(0px);
        }
    }
</style>
<template>
    <div>
        <button @click="isShow = !isShow">显示/隐藏2</button>
<!--        <transition name="test" :appear="true"> 刷新时,也能有动画效果 -->
        <transition name="test2" appear>
            <h1 v-show="isShow" class="come">你好呀2</h1>
        </transition>
    </div>
</template>

<script>
    export default {
        // eslint-disable-next-line vue/multi-word-component-names
        name: "Test2",
        data(){
            return{
                isShow:true
            }
        }
    }
</script>

<style scoped>
    /*接触过度效果去实现过度*/

    h1{
        background-color: aqua;
    }
    /*进入的起点、离开的终点*/
    .test2-enter,.test2-leave-to{
        transform: translateX(-100%);
    }
    .test2-enter-active,.test2-leave-active{
        transition: 0.5s linear;
    }
    /*进入的终点,离开的起点*/
    .test2-enter-to,.test2-leave{
        transform: translateX(0);
    }

</style>
<template>
    <div>
        <button @click="isShow = !isShow">显示/隐藏3</button>
        <transition appear
                    name="test"
                    enter-active-class="animate__animated animate__swing"
                    leave-active-class="animate__animated animate__backOutUp"
        >
            <h1 v-if="isShow">你好呀3</h1>
        </transition>
    </div>
</template>

<script>
    import 'animate.css';
    export default {
        // eslint-disable-next-line vue/multi-word-component-names
        name: "Test3",
        data() {
            return {
                isShow: true
            }
        }
    }
</script>

<style scoped>
    /*接触过度效果去实现过度*/

    h1 {
        background-color: antiquewhite;
    }


</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1323375.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】树状数组算法总结

知识概览 树状数组有两个作用&#xff1a; 快速求前缀和 时间复杂度O(log(n))修改某一个数 时间复杂度O(log(n)) 例题展示 1. 单点修改&#xff0c;区间查询 题目链接 活动 - AcWing本活动组织刷《算法竞赛进阶指南》&#xff0c;系统学习各种编程算法。主要面向…

docker中如何使用Arthas

docker中如何使用Arthas 一、操作步骤1、首先拷贝arthas包下来&#xff1a;2、其次选中你需要查看的容器ID&#xff1a;3、拷贝arthas程序包到容器目录下&#xff1a;4、进入到容器目录5、进入到第3步映射到容器的路径&#xff0c;并使用ll查看是否存在 arthas-boot.jar6、使用…

阶段十-springsecurity总结

jwt认证流程 SpringSecurity 认证过程 第一步&#xff1a; 创建一个类实现UserDetailsService接口&#xff0c;重写其中的方法 通过重写 public UserDetails loadUserByUsername(String username) 方法 从数据库校验用户输入的用户名 配置SecurityConfig Bean注入 Passwor…

用GMAT进行卫星轨道仿真

文章目录 设计飞行器预报模型配置轨道图配置预报命令运行和分析 GMAT是一跨开源轨道设计软件&#xff0c;官网挂着NASA的名字&#xff0c;看上去十分给力。 下载之后直接解压&#xff0c;可执行文件在bin目录下&#xff0c;双击GMAT.exe&#xff0c;就可以进入其欢迎界面了。G…

网络编程day4

#include<myhead.h> int task_download(int client_fd,struct sockaddr_in serve_info) {//定义变量存储下载请求包char buf[516] "";//定义变量存储文件名char filename[40] "";printf("请输入文件名&#xff1a;");scanf("%s&quo…

scrapy快加构造并发送请求

scrapy数据建模与请求 学习目标&#xff1a; 应用 在scrapy项目中进行建模应用 构造Request对象&#xff0c;并发送请求应用 利用meta参数在不同的解析函数中传递数据 1. 数据建模 通常在做项目的过程中&#xff0c;在items.py中进行数据建模 1.1 为什么建模 定义item即提前…

PDA智能巡检系统

PDA智能巡检系统是一种基于便携式数字助理&#xff08;PDA&#xff09;设备的智能化巡检管理系统。它利用PDA设备的便携性和智能化特点&#xff0c;结合巡检管理软件和相关技术&#xff0c;实现对设备、设施或场所的全面巡检和管理。在日常巡检、设备巡检、设备点检中发挥着积极…

Maven仓库上传jar和mvn命令汇总

目录 导入远程仓库 命令结构 命令解释 项目pom 输入执行 本地仓库导入 命令格式 命令解释 Maven命令汇总 mvn 参数 mvn常用命令 web项目相关命令 导入远程仓库 命令结构 mvn deploy:deploy-file -Dfilejar包完整名称 -DgroupIdpom文件中引用的groupId名 -Dartifa…

中小型企业网络综合实战案例分享

实验背景 某公司总部在厦门&#xff0c;北京、上海都有分部&#xff0c;网络结构如图所示&#xff1a; 一、网络连接描述&#xff1a; 厦门总部&#xff1a;内部网络使用SW1、SW2、SW3三台交换机&#xff0c;SW1为作为核心交换机&#xff0c;SW2、SW3作为接入层交换机&#x…

【C语言】操作符详解(五)

目录 操作符的属性&#xff1a;优先级&#xff0c;结合性 优先级 结合性 表达式求值 整形提升 算术转换 问题表达式解析 表达式1 表达式2 表达式3 总结 操作符的属性&#xff1a;优先级&#xff0c;结合性 优先级 ⭐优先级&#xff1a;优先级指的是&#xff0c;如果一…

九牧:科技卫浴,长期主义

“没有做错什么&#xff0c;但却输给了时代”&#xff0c;这是人们给当年手机巨头诺基亚的注解。 谁也没有想到&#xff0c;曾在手机行业称雄的诺基亚&#xff0c;最终败给了时代。当年&#xff0c;在2G向3G、4G跨越的时候&#xff0c;苹果、微软的iOS和安卓系统将手机从简单的…

实验三 MapReduce编程

实验目的&#xff1a; 1.掌握MapReduce的基本编程流程&#xff1b; 2.掌握MapReduce序列化的使用&#xff1b; 实验内容&#xff1a; 一、在本地创建名为MapReduceTest的Maven工程&#xff0c;在pom.xml中引入相关依赖包&#xff0c;配置log4j.properties文件&#xff0c;搭…

个人老师可直接使用的在线授课软件

大家好&#xff0c;我是 Java陈序员。 大学四年&#xff0c;疫情就占了三年&#xff01; 以前小时候曾经梦想着不用去学校上课&#xff0c;在家就能上课&#xff0c;这不前几年疫情的时候就成为了现实&#xff01; 随着互联网的兴起&#xff0c;各种线下的活动都可以搬到线上…

sql_lab靶场搭建以及存在的一些问题

sql_lab靶场搭建问题 首先检查小皮版本 把小皮改到5.3.29版本如果没有可以直接点击更多版本进行选择安装 当版本不对时则会暴出这种错误 SETTING UP THE DATABASE SCHEMA AND POPULATING DATA IN TABLES: Fatal error: Uncaught Error: Call to undefined function mysql_co…

SSH的交互原理(wireshark的分析)

SSH的交换原理&#xff08;wireshark篇&#xff09; 首先要想了解ssh的交换原理&#xff0c;必须要先了解他的加密方式&#xff0c;他的加密方式是对称加密&#xff0c;和公钥加密。什么意思呢&#xff1f; 首先我们向服务器发送一个请求&#xff0c;然后服务器会发给我们他的…

5个免费、跨平台的SQLite数据库可视化工具

前言 SQLite是一个轻量级的嵌入式关系型数据库&#xff0c;目前最新的版本是 SQLite3。今天推荐5个实用的SQLite数据库可视化工具(GUI)&#xff0c;帮助大家更好的管理SQLite数据库。 什么是SQLite&#xff1f; SQLite是一个轻量级的嵌入式关系型数据库&#xff0c;它以一个…

3d游戏公司选择云电脑进行云办公有哪些优势

随着游戏行业的不断发展&#xff0c;很多的游戏制作公司也遇到了很多的难题&#xff0c;比如硬件更换成本高、团队协同难以及效率低下等问题&#xff0c;那么如何解决游戏行业面临的这些行业痛点&#xff0c;以及游戏制作公司选择云电脑进行云办公有哪些优势&#xff1f;一起来…

Word的兼容性问题很常见,禁用兼容模式虽步不是最有效的,但可以解决兼容性问题

当你在较新版本的Word应用程序中打开用较旧版本的Word创建的文档时&#xff0c;会出现兼容性问题。错误通常发生在文件名附近&#xff08;兼容模式&#xff09;。兼容性模式问题&#xff08;暂时&#xff09;禁用Word功能&#xff0c;从而限制使用较新版本Word的用户编辑文档。…

查看git的帮助信息

说明 在cmd窗口、或者git Bash shell下执行git --help或者git -h命令&#xff0c;可以查看git的帮助信息。 执行git <command> --help命令可以查看某个命令的帮助信息&#xff0c;其中<command>表示某个具体的命令。 示例1&#xff1a;在git Bash shell下运行git…

JavaOOP篇----第六篇

系列文章目录 文章目录 系列文章目录前言一、String 是最基本的数据类型吗?二、float f=3.4;是否正确?三、short s1 = 1; s1 = s1 + 1;有错吗?short s1 = 1; s1 +=1; 有错吗?四、重载和重写的区别前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住…