## 教学一体化项目模板介绍 #### 目录 ----`leachinontecration olattorm temolate` ----模板名称 ​ ----`node modules` ----依赖包 ​ ----`public` ----静态文件相关 ​ ----`scripts` ----项目钩子脚本文件 ​ ----`src` ----根目录开发主要文件 ​ ----`api` ----接口文件 ​ ----assets ----静态资源(图片图标) ​ ----`copmonents` ----全局组件 ​ ----Layout ----layout固定组件 ​ ----`router` ----路由 ​ ----`store` ----仓库`pinia` ​ ----styles ----全局样式文件 ​ ----`index.scss` ----全局样式 ​ ----`variable.scss` ----全局`scss`变量 ​ ----`utils` -----封装工具文件 ​ ----`request.ts` ----封装的请求文件 ​ ----`views` ----页面文件 ​ ----`App.vue` ----项目根组件 ​ ----`main.ts` ----项目入口文件 ​ ----`permission.ts` ----路由拦截器文件 ​ ----`.env.development` ----开发环境变量 ​ ----`.env.production` ----生产环境变量 ​ ----`.env.test` ----测试环境变量 ​ ----` .eslintignore` ----代码校验排除文件 ​ ----`.eslintrc.cjs` ----代码校验文件 ​ ----`.gitignore` ----`git`提交排除文件 ​ ----`.prettierignore` ----代码美化排除文件 ​ ----` .prettierrc.json` ----代码美化配置文件 ​ ----`.stylelintignore` ----`css`校验排除文件 ​ ----` .stylelintrc.cjs` ----`css`校验文件 ​ ----`index.html` ----挂载点 ​ ----`package.json` ----项目配置文件 ​ ----`tsconfig.json` ----`TypeScript`配置文件 ​ ----`vite.config.ts` ----打包配置文件 #### 图标组件 `components`文件下`SvgIcon` 为全局图标组件 用法: ```vue
``` `svg`图标下载 https://www.iconfont.cn/ 选择图标下载`svg`格式修改文件名引入文件即可使用 #### vue3组件传值教程 不管是vue2还是vue3,组件通信方式很重要,不管是项目还是面试都是经常用到的知识点。 **比如:vue2组件通信方式** **props:**可以实现父子组件、子父组件、甚至兄弟组件通信 **自定义事件**:可以实现子父组件通信 **全局事件总线$bus**:可以实现任意组件通信 **pubsub:**发布订阅模式实现任意组件通信 **vuex**:集中式状态管理容器,实现任意组件通信 **ref**:父组件获取子组件实例VC,获取子组件的响应式数据以及方法 **slot:**插槽(默认插槽、具名插槽、作用域插槽)实现父子组件通信........ ### 1.1props props可以实现父子组件通信,在vue3中我们可以通过defineProps获取父组件传递的数据。且在组件内部不需要引入defineProps方法可以直接使用! **父组件给子组件传递数据** ``` ``` **子组件获取父组件传递数据:方式1** ``` let props = defineProps({ info:{ type:String,//接受的数据类型 default:'默认参数',//接受默认数据 }, money:{ type:Number, default:0 }}) ``` **子组件获取父组件传递数据:方式2** ``` let props = defineProps(["info",'money']); ``` 子组件获取到props数据就可以在模板中使用了,但是切记props是只读的(只能读取,不能修改) ### 1.2自定义事件 在vue框架中事件分为两种:一种是原生的DOM事件,另外一种自定义事件。 原生DOM事件可以让用户与网页进行交互,比如click、dbclick、change、mouseenter、mouseleave.... 自定义事件可以实现子组件给父组件传递数据 #### 1.2.1原生DOM事件 代码如下: ```
      我是祖国的老花骨朵
 
``` 当前代码级给pre标签绑定原生DOM事件点击事件,默认会给事件回调注入event事件对象。当然点击事件想注入多个参数可以按照下图操作。但是切记注入的事件对象务必叫做$event. ```
我要传递多个参数
``` 在vue3框架click、dbclick、change(这类原生DOM事件),不管是在标签、自定义标签上(组件标签)都是原生DOM事件。 **** #### 1.2.2自定义事件 自定义事件可以实现子组件给父组件传递数据.在项目中是比较常用的。 比如在父组件内部给子组件(Event2)绑定一个自定义事件 ``` ``` 在Event2子组件内部触发这个自定义事件 ``` ``` 我们会发现在script标签内部,使用了defineEmits方法,此方法是vue3提供的方法,不需要引入直接使用。defineEmits方法执行,传递一个数组,数组元素即为将来组件需要触发的自定义事件类型,此方执行会返回一个$emit方法用于触发自定义事件。 当点击按钮的时候,事件回调内部调用$emit方法去触发自定义事件,第一个参数为触发事件类型,第二个、三个、N个参数即为传递给父组件的数据。 需要注意的是:代码如下 ``` ``` 正常说组件标签书写@click应该为原生DOM事件,但是如果子组件内部通过defineEmits定义就变为自定义事件了 ``` let $emit = defineEmits(["xxx",'click']); ``` ### 1.3全局事件总线 全局事件总线可以实现任意组件通信,在vue2中可以根据VM与VC关系推出全局事件总线。 但是在vue3中没有Vue构造函数,也就没有Vue.prototype.以及组合式API写法没有this, 那么在Vue3想实现全局事件的总线功能就有点不现实啦,如果想在Vue3中使用全局事件总线功能 可以使用插件mitt实现。 **mitt:官网地址:https://www.npmjs.com/package/mitt** ### 1.4v-model v-model指令可是收集表单数据(数据双向绑定),除此之外它也可以实现父子组件数据同步。 而v-model实指利用props[modelValue]与自定义事件[update:modelValue]实现的。 下方代码:相当于给组件Child传递一个props(modelValue)与绑定一个自定义事件update:modelValue 实现父子组件数据同步 ``` ``` 在vue3中一个组件可以通过使用多个v-model,让父子组件多个数据同步,下方代码相当于给组件Child传递两个props分别是pageNo与pageSize,以及绑定两个自定义事件update:pageNo与update:pageSize实现父子数据同步 ``` ``` ### 1.5useAttrs 在Vue3中可以利用useAttrs方法获取组件的属性与事件(包含:原生DOM事件或者自定义事件),次函数功能类似于Vue2框架中$attrs属性与$listeners方法。 比如:在父组件内部使用一个子组件my-button ``` ``` 子组件内部可以通过useAttrs方法获取组件属性与事件.因此你也发现了,它类似于props,可以接受父组件传递过来的属性与属性值。需要注意如果defineProps接受了某一个属性,useAttrs方法返回的对象身上就没有相应属性与属性值。 ``` ``` ### 1.6ref与$parent ref,提及到ref可能会想到它可以获取元素的DOM或者获取子组件实例的VC。既然可以在父组件内部通过ref获取子组件实例VC,那么子组件内部的方法与响应式数据父组件可以使用的。 比如:在父组件挂载完毕获取组件实例 父组件内部代码: ``` ``` 但是需要注意,如果想让父组件获取子组件的数据或者方法需要通过defineExpose对外暴露,因为vue3中组件内部的数据对外“关闭的”,外部不能访问 ``` ``` $parent可以获取某一个组件的父组件实例VC,因此可以使用父组件内部的数据与方法。必须子组件内部拥有一个按钮点击时候获取父组件实例,当然父组件的数据与方法需要通过defineExpose方法对外暴露 ``` ``` ### 1.7provide与inject **provide[提供]** **inject[注入]** vue3提供两个方法provide与inject,可以实现隔辈组件传递参数 组件组件提供数据: provide方法用于提供数据,此方法执需要传递两个参数,分别提供数据的key与提供数据value ``` ``` 后代组件可以通过inject方法获取数据,通过key获取存储的数值 ``` ``` ### 1.8pinia **pinia官网:https://pinia.web3doc.top/** pinia也是集中式管理状态容器,类似于vuex。但是核心概念没有mutation、modules,使用方式参照官网 ### 1.9slot 插槽:默认插槽、具名插槽、作用域插槽可以实现父子组件通信. **默认插槽:** 在子组件内部的模板中书写slot全局组件标签 ``` ``` 在父组件内部提供结构:Todo即为子组件,在父组件内部使用的时候,在双标签内部书写结构传递给子组件 注意开发项目的时候默认插槽一般只有一个 ```

我是默认插槽填充的结构

``` **具名插槽:** 顾名思义,此插槽带有名字在组件内部留多个指定名字的插槽。 下面是一个子组件内部,模板中留两个插槽 ``` ``` 父组件内部向指定的具名插槽传递结构。需要注意v-slot:可以替换为# ``` ``` **作用域插槽** 作用域插槽:可以理解为,子组件数据由父组件提供,但是子组件内部决定不了自身结构与外观(样式) 子组件Todo代码如下: ``` ``` 父组件内部代码如下: ``` ``` ##