Vue的脚手架

脚手架配置

脚手架文档: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>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习或机器学习的模型部署相关的初步了解及分析

机器学习-深度学习 部署相关资料文档 这是上班之后的第一个文档&#xff0c;由于项目原因需要去了解一些和模型部署相关的知识&#xff0c;所以就简单了解了一下相应的部署引擎和框架&#xff0c;也是刚刚开始学习&#xff0c;如果有什么写的不对的欢迎大家交流&#xff0c;看…

Git 储藏(stash)用法

储藏的基本用法 保存当前的更改 1、查看储藏 git stash list2、更改保存到一个储藏中&#xff1a; git stash save "info"其中&#xff0c;“info” 是可选的注释信息&#xff0c;可以简要描述这个储藏的内容。 3、恢复之前保存的更改 可以使用下面的命令将之前…

微信小程序动态导航栏(uniapp + vant)

本文使用到vant的van-tabbar组件来实现 一、uniapp整合vant ui vant小程序版本&#xff1a;https://vant-contrib.gitee.io/vant-weapp/#/home 注&#xff1a;vant并没有uniapp的版本&#xff0c;所以此处是引入小程序版本的ui 1. 下载vant编译后代码 https://github.com/you…

新手上路:自动驾驶行业快速上手指南

文章目录 1.自动驾驶技术的发展1.1 工业革命驱动自动驾驶技术发展1.2 想象中的未来&#xff1a;科幻作品中的自动驾驶汽车1.3 自动驾驶技术萌芽与尝试1.4 百花争鸣&#xff1a;自动驾驶科技巨头与创业公司并进 2.个人开发者&#xff0c;如何玩转自动驾驶&#xff1f;2.1 灵活易…

开源 AI 研发提效方案 Unit Mesh 总结

回顾 2023 年&#xff0c;可以明显地看到生成式 AI 带给软件工程带来的新思考&#xff0c;每个组织也在探索结合生成式 AI 的可能性。Unit Mesh (https://github.com/unit-mesh) GitHub 组织正是基于我与我的同事的研究&#xff0c;所构建的一系列围绕于生成式 AI 应用于软件研…

基于ssm国外摇滚乐队交流和周边售卖系统论文

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对国外摇滚乐队交流和周边售卖信息管理混乱&#xff0c;出错率高&…

CUMT-Java复习--抽象类和接口

目录 一、抽象类 1、定义抽象类 2、实现一个抽象类 二、接口 1、定义接口 2、实现接口 3、接口继承 4、接口和抽象类的相似之处 5、接口和抽象类的区别 三、instanceof关键字 一、抽象类 1、定义抽象类 抽象类是对于一类相同的具体概念的抽象。 抽象类和抽象方法都…

密码强度的提升与网络安全意识

随着互联网的快速发展&#xff0c;网络安全问题日益突出&#xff0c;其中密码安全作为网络世界的第一道防线&#xff0c;其重要性不言而喻。本文将从密码强度的提升和网络安全意识普及两个方面&#xff0c;探讨如何在日益复杂的网络环境中保障个人信息安全。 随机密码生成器 |…

【2023 英特尔On技术创新大会直播 |我与英特尔的初次相遇】—— AIPC探索下一代的物联网时代

&#x1f308;个人主页: Aileen_0v0 &#x1f525;系列专栏:英特尔技术学习专栏 &#x1f4ab;个人格言:"没有罗马,那就自己创造罗马~" 目录 硅谷经济的发展与挑战 Intel开发者云与AI技术的应用 AI压缩技术的发展与应用 英特尔与阿里巴巴在AI领域的合作 AIPC时代的…

RocketMQ系统性学习-RocketMQ原理分析之消息的可靠性以及有序性如何保证

文章目录 消息的可靠性如何保证&#xff1f;消息的有序性如何保证&#xff1f; 消息的可靠性如何保证&#xff1f; 要保证消息的可靠性&#xff0c;先来思考一下从哪些方面保证呢&#xff1f; 这要看消息的生命周期&#xff0c;既然保证可靠性&#xff0c;那么就是要保证 A 发…

理解并在虚拟化策略中实施 QEMU

● QEMU 是一种流行的开源机器模拟器。 ● QEMU 支持硬件虚拟化扩展&#xff08;Intel VT-x 和 AMD-V&#xff09;。 ● QEMUCare 为基于 QEMU 的虚拟化系统提供实时修补解决方案。 虚拟化现已成为现代 IT 基础设施的支柱&#xff0c;使组织能够实现前所未有的灵活性、可扩展…

pycharm运行正常,但命令行执行提示module不存在的多种解决方式

问题描述 在执行某个测试模块时出现提示&#xff0c;显示自定义模块data不存在&#xff0c;但是在PyCharm下运行正常。错误信息如下&#xff1a; Traceback (most recent call last):File "/run/channelnterface-autocase/testcases/test_chanel_detail.py", line 2…

直播种类之VR全景直播

VR全景直播是一种结合虚拟现实技术和直播的全新体验。通过全景相机拍摄&#xff0c;观众可以身临其境地感受直播现场的氛围和真实感&#xff0c;提供逼真的观看体验。 VR全景直播的优势在于: 1.身临其境的观看体验:观众可以像真的在现场一样&#xff0c;通过虚拟现实设备探索…

基于python的leetcode算法介绍之递归

文章目录 零 算法介绍一 简单示例 辗转相除法Leetcode例题与思路[509. 斐波那契数](https://leetcode.cn/problems/fibonacci-number/)解题思路&#xff1a;题解&#xff1a; [206. 反转链表](https://leetcode.cn/problems/reverse-linked-list/)解题思路&#xff1a;题解&…

OpenHarmony开发环境快速搭建(无需命令行)

一. 搭建Windows环境 在嵌入式开发中&#xff0c;很多开发者习惯于使用Windows进行代码的编辑&#xff0c;比如使用Windows的Visual Studio Code进行OpenHarmony代码的开发。但当前阶段&#xff0c;大部分的开发板源码还不支持在Windows环境下进行编译&#xff0c;如Hi3861、H…

数字助听器如何处理声音?

数字助听器如何处理声音&#xff1f; 助听器的作用不仅仅是放大声音。为了创建可改进语音识别的自定义声音配置文件&#xff0c;他们以多种方式处理声音。 麦克风 与人耳一样&#xff0c;数字助听器不直接处理声波。首先是麦克风。它们充当换能器&#xff0c;捕获机械波能并将…

Verilog 仿真可视化

Verilog 仿真可视化 飞多学堂 飞多学堂 2023-12-11 09:37 Posted on 山东 DigitalJS 是一个基于 JavaScript 实现的开源数字电路模拟器&#xff0c;旨在模拟由硬件设计工具&#xff08;如 Yosys&#xff09;合成的电路。由弗罗茨瓦夫大学的Marek Materzok开发&#xff0c;源文…

手机数码品牌网站建设的作用是什么

手机数码产品几乎已经成为成年人必备的&#xff0c;包括手机、电脑、摄像机、键盘配件等&#xff0c;同时市场中相关企业也非常多&#xff0c;消费者可供选择的商品类型也很多样&#xff0c;而对企业来讲&#xff0c;只有不断提升品牌形象、获客拉新等才能不断提升企业地位&…

easyexcel常见注解

easyexcel常见注解 一、依赖 <!--阿里巴巴EasyExcel依赖--><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.10</version></dependency>二、常见注解 ExcelProperty 注解中…

绝地求生什么游戏?

绝地求生是一款由蓝洞公司开发并发行的多人在线生存竞技游戏&#xff0c;也是一款备受玩家热爱和追捧的射击游戏。游戏灵感源自于日本电影《葛洛历亚号》&#xff0c;玩家将扮演一名跳伞降落在荒岛上的幸存者&#xff0c;通过收集资源、与其他玩家进行战斗来生存到最后一名&…