当前位置: 首页 > news >正文

什么网站可以做卷子网站建设背景朝阳

什么网站可以做卷子,网站建设背景朝阳,网站后台排版,做社区网站用什么程序好文章目录 Vue3简介创建Vue3.0工程使用 vue-cli 创建使用 vite 创建Vue3工程结构变化 常用 Composition API拉开序幕的setupref函数reactive函数Vue3.0中的响应式原理vue2.x的响应式Vue3.0的响应式 reactive对比refsetup的两个注意点计算属性与监视computed函数watch函数watchEf… 文章目录 Vue3简介创建Vue3.0工程使用 vue-cli 创建使用 vite 创建Vue3工程结构变化 常用 Composition API拉开序幕的setupref函数reactive函数Vue3.0中的响应式原理vue2.x的响应式Vue3.0的响应式 reactive对比refsetup的两个注意点计算属性与监视computed函数watch函数watchEffect函数 生命周期自定义hook函数toRef 其它 Composition APIshallowReactive 与 shallowRefreadonly 与 shallowReadonlytoRaw 与 markRawcustomRefprovide 与 inject响应式数据的判断 Composition API 的优势Options API 存在的问题Composition API 的优势 新的组件FragmentTeleportSuspense 其他全局API的转移其他改变 参考https://www.bilibili.com/video/BV1Zy4y1K7SH Vue3简介 2020年9月18日Vue.js发布3.0版本代号One Piece海贼王 Vue3带来了什么 性能的提升 打包大小减少41% 初次渲染快55%, 更新渲染快133% 内存减少54% … 源码的升级 使用Proxy代替defineProperty实现响应式 重写虚拟DOM的实现和Tree-Shaking … 拥抱TypeScript Vue3可以更好的支持TypeScript .新的特性 Composition API组合API setup配置ref与reactivewatch与watchEffectprovide与inject… 新的内置组件 FragmentTeleportSuspense 其他改变 新的生命周期钩子data 选项应始终被声明为一个函数移除keyCode支持作为 v-on 的修饰符… 创建Vue3.0工程 使用 vue-cli 创建 官方文档https://cli.vuejs.org/zh/guide/creating-a-project.html#vue-create ## 查看vue/cli版本确保vue/cli版本在4.5.0以上 vue --version ## 安装或者升级你的vue/cli npm install -g vue/cli ## 创建 vue create vue_test ## 启动 cd vue_test npm run serve使用 vite 创建 官方文档https://v3.cn.vuejs.org/guide/installation.html#vite 什么是vite—— 新一代前端构建工具。优势如下 开发环境中无需打包操作可快速的冷启动。轻量快速的热重载HMR。真正的按需编译不再等待整个应用编译完成。 vite和vuecli的区别是什么 Vite 和 Vue CLI 都是 Vue.js 的开发和构建工具但它们有一些联系和区别。¹² Vite 和 Vue CLI 都可以提供基本的项目脚手架和开发服务器都支持 Vue 单文件组件、TypeScript、CSS 预处理器等特性。Vite 和 Vue CLI 的主要区别在于它们使用的底层技术不同。Vue CLI 基于 Webpack 封装生产环境和开发环境都是基于 Webpack 打包。Vite 是基于原生 ES6 Modules在生产环境下打包使用的是 Rollup。Vite 在开发环境下无需对代码进行打包浏览器可以直接调用所以说 Vite 因为基于浏览器的原生功能省掉了打包过程在开发环境中体验极好。Vite 也使用了 esbuild 来预构建依赖提高了性能和兼容性。Vue CLI 在开发环境下需要对代码进行打包这会导致启动和更新速度较慢尤其是在大型项目中。Vue CLI 也提供了一些 Webpack 启发的功能比如从 JS 中导入 CSS 文件基于文件系统的相对路径引用资源等。Vite 和 Vue CLI 都是可扩展的都支持配置和插件的方式来添加自定义的功能。Vite 的插件基于 Rollup 插件Vue CLI 的插件基于 Webpack 插件。 ## 创建工程 npm init vite-app project-name ## 进入工程目录 cd project-name ## 安装依赖 npm install ## 运行 npm run devVue3工程结构变化 这里以vue-cli创建的Vue3工程为例我们发现入口文件发生了比较大的变化 每个 Vue 应用都是通过 createApp 函数创建一个新的 应用实例我们传入 createApp 的对象实际上是一个组件每个应用都需要一个“根组件”其他组件将作为其子组件。应用实例必须在调用了 .mount() 方法后才会渲染出来。该方法接收一个“容器”参数可以是一个实际的 DOM 元素或是一个 CSS 选择器字符串.mount() 方法应该始终在整个应用配置和资源注册完成后被调用。同时请注意不同于其他资源注册方法它的返回值是根组件实例而非应用实例 常用 Composition API 官方文档: https://v3.cn.vuejs.org/guide/composition-api-introduction.html 拉开序幕的setup 理解Vue3.0中一个新的配置项值为一个函数。setup是所有Composition API组合API“ 表演的舞台 ”。组件中所用到的数据、方法等等均要配置在setup中。setup函数的两种返回值 若返回一个对象则对象中的属性、方法, 在模板中均可以直接使用。返回给模板模板才能使用若返回一个渲染函数则可以自定义渲染内容。了解 注意点 尽量不要与Vue2.x配置混用 Vue2.x配置data、methos、computed…中可以访问到setup中的属性、方法。但在setup中不能访问到Vue2.x配置data、methos、computed…。如果有重名, setup优先。 setup不能是一个async函数因为返回值不再是return的对象, 而是promise, 模板看不到return对象中的属性。后期也可以返回一个Promise实例但需要Suspense和异步组件的配合 ref函数 作用: 定义一个响应式的数据语法: const xxx ref(initValue) 创建一个包含响应式数据的引用对象reference对象简称ref对象。JS中操作数据 xxx.value模板中读取数据: 不需要.value直接div{{xxx}}/div 备注 接收的数据可以是基本类型、也可以是对象类型。基本类型的数据响应式依然是靠Object.defineProperty()的get与set完成的。对象类型的数据内部 “ 求助 ” 了Vue3.0中的一个新函数—— reactive函数。 reactive函数 作用: 定义一个对象类型的响应式数据基本类型不要用它要用ref函数语法const 代理对象 reactive(源对象)接收一个对象或数组返回一个代理对象Proxy的实例对象简称proxy对象reactive定义的响应式数据是“深层次的”。内部基于 ES6 的 Proxy 实现通过代理对象操作源对象内部数据进行操作。 Vue3.0中的响应式原理 vue2.x的响应式 实现原理 对象类型通过Object.defineProperty()对属性的读取、修改进行拦截数据劫持。 数组类型通过重写更新数组的一系列方法来实现拦截。对数组的变更方法进行了包裹。 Object.defineProperty(data, count, {get () {}, set () {} })存在问题 新增属性、删除属性, 界面不会更新。直接通过下标修改数组, 界面不会自动更新。 Vue3.0的响应式 实现原理: 通过Proxy代理: 拦截对象中任意属性的变化, 包括属性值的读写、属性的添加、属性的删除等。通过Reflect反射: 对源对象的属性进行操作。MDN文档中描述的Proxy与Reflect Proxyhttps://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Proxy Reflecthttps://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Reflect new Proxy(data, {// 拦截读取属性值get (target, prop) {return Reflect.get(target, prop)},// 拦截设置属性值或添加新属性set (target, prop, value) {return Reflect.set(target, prop, value)},// 拦截删除属性deleteProperty (target, prop) {return Reflect.deleteProperty(target, prop)} })proxy.name tom reactive对比ref 从定义数据角度对比 ref用来定义基本类型数据。reactive用来定义对象或数组类型数据。备注ref也可以用来定义对象或数组类型数据, 它内部会自动通过reactive转为代理对象。 从原理角度对比 ref通过Object.defineProperty()的get与set来实现响应式数据劫持。reactive通过使用Proxy来实现响应式数据劫持, 并通过Reflect操作源对象内部的数据。 从使用角度对比 ref定义的数据操作数据需要.value读取数据时模板中直接读取不需要.value。reactive定义的数据操作数据与读取数据均不需要.value。 setup的两个注意点 setup执行的时机 在beforeCreate之前执行一次this是undefined。 setup的参数 props值为对象包含组件外部传递过来且组件内部props声明接收了的属性。context上下文对象 attrs: 值为对象包含组件外部传递过来但没有在props配置中声明的属性接收了的不在里面, 相当于 this.$attrs。slots: 收到的插槽内容, 相当于 this.$slots。emit: 用来触发自定义事件, 相当于 this.$emit。 计算属性与监视 computed函数 与Vue2.x中computed配置功能一致 写法 import {computed} from vuesetup(){...//计算属性——简写let fullName computed((){return person.firstName - person.lastName})//计算属性——完整let fullName computed({get(){return person.firstName - person.lastName},set(value){const nameArr value.split(-)person.firstName nameArr[0]person.lastName nameArr[1]}}) }watch函数 与Vue2.x中watch配置功能一致 两个小“坑” 监视reactive定义的响应式数据时oldValue无法正确获取、强制开启了深度监视deep配置失效也就是说false也没用还是可以监视。监视reactive定义的响应式数据中某个属性时deep配置有效此时如果涉及深度监视要开启deep。 //情况一监视ref定义的响应式数据 watch(sum,(newValue,oldValue){console.log(sum变化了,newValue,oldValue) },{immediate:true})//情况二监视多个ref定义的响应式数据 watch([sum,msg],(newValue,oldValue){console.log(sum或msg变化了,newValue,oldValue) }) /* 情况三监视reactive定义的响应式数据若watch监视的是reactive定义的响应式数据则无法正确获得oldValue若watch监视的是reactive定义的响应式数据则强制开启了深度监视 */ watch(person,(newValue,oldValue){console.log(person变化了,newValue,oldValue) },{immediate:true,deep:false}) //此处的deep配置不再奏效//情况四监视reactive定义的响应式数据中的某个属性不能这么用 watch(()person.job,(newValue,oldValue){console.log(person的job变化了,newValue,oldValue) },{immediate:true,deep:true}) //情况五监视reactive定义的响应式数据中的某些属性要传入一个函数 watch([()person.job,()person.name],(newValue,oldValue){console.log(person的job变化了,newValue,oldValue) },{immediate:true,deep:true})//特殊情况 watch(()person.job,(newValue,oldValue){console.log(person的job变化了,newValue,oldValue) },{deep:true}) //此处由于监视的是reactive素定义的对象中的某个属性所以deep配置有效watchEffect函数 watch的套路是既要指明监视的属性也要指明监视的回调。 watchEffect的套路是不用指明监视哪个属性监视的回调中用到哪个属性那就监视哪个属性。 watchEffect有点像computed 但computed注重的计算出来的值回调函数的返回值所以必须要写返回值。而watchEffect更注重的是过程回调函数的函数体所以不用写返回值。 //watchEffect所指定的回调中用到的数据只要发生变化则直接重新执行回调。 watchEffect((){const x1 sum.valueconst x2 person.ageconsole.log(watchEffect配置的回调执行了) })生命周期 Vue3.0中可以继续使用Vue2.x中的生命周期钩子也就是说通过配置型的形式但有有两个被更名 beforeDestroy改名为 beforeUnmountdestroyed改名为 unmounted 同时Vue3.0也提供了 Composition API 形式的生命周期钩子也就是说写在setup中的形式与Vue2.x中钩子对应关系如下 beforeCreatesetup()createdsetup()beforeMount onBeforeMountmountedonMountedbeforeUpdateonBeforeUpdateupdated onUpdatedbeforeUnmount onBeforeUnmountunmounted onUnmounted 自定义hook函数 什么是hook—— 本质是一个函数把setup函数中使用的Composition API进行了封装。 类似于vue2.x中的mixin。 自定义hook的优势: 复用代码, 让setup中的逻辑更清楚易懂。 toRef 作用创建一个 ref 对象其value值指向另一个对象中的某个属性。 语法const name toRef(person,name) 应用: 要将响应式对象中的某个属性单独提供给外部使用时。 扩展toRefs与toRef功能一致但可以批量创建多个 ref 对象语法toRefs(person) toRef 的作用和使用场景是这样的 toRef 的作用是可以将响应式对象中的某个属性单独提取出来作为一个响应式数据使用这样可以方便地在不同的地方引用和修改这个属性而不影响其他属性。toRef 的使用场景是当你需要在 setup 函数中使用响应式对象中的某个属性时你可以使用 toRef 来创建一个 ref 对象然后在模板或其他地方使用这个 ref 对象。这样你可以避免在 setup 函数中返回整个响应式对象从而减少不必要的渲染和更新。 以下是一个 toRef 的使用示例¹ templatedivp{{ name }}/pp{{ age }}/pbutton clickchangeName改变名字/buttonbutton clickchangeAge改变年龄/button/div /templatescript import { reactive, toRef } from vue; export default {setup() {// 创建一个响应式对象const person reactive({name: 张三,age: 18,});// 使用 toRef 提取 name 属性const name toRef(person, name);// 定义一个改变 name 的方法const changeName () {name.value 李四;};// 定义一个改变 age 的方法const changeAge () {person.age;};// 返回给模板return {name, //name具有响应式age: person.age, //age不具有响应式changeName,changeAge,};}, }; /script其它 Composition API shallowReactive 与 shallowRef shallowReactive只处理对象最外层属性的响应式浅响应式。 shallowRef只处理基本数据类型的响应式, 不进行对象的响应式处理。 什么时候使用? 如果有一个对象数据结构比较深, 但变化时只是外层属性变化 shallowReactive。如果有一个对象数据后续功能不会修改该对象中的属性而是生新的对象来替换 shallowRef。 readonly 与 shallowReadonly readonly: 让一个响应式数据变为只读的深只读。shallowReadonly让一个响应式数据变为只读的浅只读。应用场景: 不希望数据被修改时。 toRaw 与 markRaw toRaw 作用将一个由reactive生成的响应式对象转为普通对象。使用场景用于读取响应式对象对应的普通对象对这个普通对象的所有操作不会引起页面更新。 markRaw 作用标记一个对象使其永远不会再成为响应式对象。应用场景: 有些值不应被设置为响应式的例如复杂的第三方类库等。当渲染具有不可变数据源的大列表时跳过响应式转换可以提高性能。 customRef 作用创建一个自定义的 ref并对其依赖项跟踪和更新触发进行显式控制。 实现防抖效果 templateinput typetext v-modelkeywordh3{{keyword}}/h3 /templatescriptimport {ref,customRef} from vueexport default {name:Demo,setup(){// let keyword ref(hello) //使用Vue准备好的内置ref//自定义一个myReffunction myRef(value,delay){let timer//通过customRef去实现自定义return customRef((track,trigger){return{get(){track() //告诉Vue这个value值是需要被“追踪”的return value},set(newValue){clearTimeout(timer)timer setTimeout((){value newValuetrigger() //告诉Vue去更新界面},delay)}}})}let keyword myRef(hello,500) //使用程序员自定义的refreturn {keyword}}} /scriptprovide 与 inject 作用实现祖与后代组件间通信 套路父组件有一个 provide 选项来提供数据后代组件有一个 inject 选项来开始使用这些数据 具体写法 祖组件中 setup(){......let car reactive({name:奔驰,price:40万})provide(car,car)...... }后代组件中 setup(props,context){......const car inject(car)return {car}...... }响应式数据的判断 isRef: 检查一个值是否为一个 ref 对象isReactive: 检查一个对象是否是由 reactive 创建的响应式代理isReadonly: 检查一个对象是否是由 readonly 创建的只读代理isProxy: 检查一个对象是否是由 reactive 或者 readonly 方法创建的代理 Composition API 的优势 Options API 存在的问题 使用传统OptionsAPI中新增或者修改一个需求就需要分别在datamethodscomputed里修改 。 Composition API 的优势 我们可以更加优雅的组织我们的代码函数。让相关功能的代码更加有序的组织在一起。 新的组件 Fragment 在Vue2中: 组件必须有一个根标签在Vue3中: 组件可以没有根标签, 内部会将多个标签包含在一个Fragment虚拟元素中好处: 减少标签层级, 减小内存占用 Teleport 什么是Teleport—— Teleport 是一种能够将我们的组件html结构移动到指定位置的技术。 teleport to移动位置div v-ifisShow classmaskdiv classdialogh3我是一个弹窗/h3button clickisShow false关闭弹窗/button/div/div /teleportSuspense 等待异步组件时渲染一些额外内容让应用有更好的用户体验 使用步骤 异步引入组件 import {defineAsyncComponent} from vue const Child defineAsyncComponent(()import(./components/Child.vue))使用Suspense包裹组件并配置好default与 fallback templatediv classapph3我是App组件/h3Suspensetemplate v-slot:defaultChild//templatetemplate v-slot:fallbackh3加载中...../h3/template/Suspense/div /template其他 全局API的转移 Vue 2.x 有许多全局 API 和配置。 例如注册全局组件、注册全局指令等。 //注册全局组件 Vue.component(MyButton, {data: () ({count: 0}),template: button clickcountClicked {{ count }} times./button })//注册全局指令 Vue.directive(focus, {inserted: el el.focus() }Vue3.0中对这些API做出了调整 将全局的API即Vue.xxx调整到应用实例app上 2.x 全局 APIVue3.x 实例 API (app)Vue.config.xxxxapp.config.xxxxVue.config.productionTip移除Vue.componentapp.componentVue.directiveapp.directiveVue.mixinapp.mixinVue.useapp.useVue.prototypeapp.config.globalProperties 其他改变 data选项应始终被声明为一个函数。 过度类名的更改 Vue2.x写法 .v-enter, .v-leave-to {opacity: 0; } .v-leave, .v-enter-to {opacity: 1; }Vue3.x写法 .v-enter-from, .v-leave-to {opacity: 0; }.v-leave-from, .v-enter-to {opacity: 1; }移除keyCode作为 v-on 的修饰符同时也不再支持config.keyCodes 移除v-on.native修饰符 父组件中绑定事件 my-componentv-on:closehandleComponentEventv-on:clickhandleNativeClickEvent /子组件中声明自定义事件 scriptexport default {emits: [close]} /script移除过滤器filter 过滤器虽然这看起来很方便但它需要一个自定义语法打破大括号内表达式是 “只是 JavaScript” 的假设这不仅有学习成本而且有实现成本建议用方法调用或计算属性去替换过滤器。 …
http://www.pierceye.com/news/909863/

相关文章:

  • 网站开发在线浏览pdfwin7可以做网站吗
  • 手机上制作网站的软件巢湖有没有专门做网站的公司
  • 哪里有做企业网站的wordpress 主题类型
  • 什么是网站平台开发工具网站怎么做筛选功能的代码
  • 自建站 外贸军事内参消息
  • 化妆品网站建设实训总结坂田建设网站
  • 成都网站建设哪家专业嘉峪关市建设局网站
  • 企业策划 企业网站建设 品牌设计下载住小帮app看装修
  • wordpress文章内图片不显示不出来成都seo整站
  • 鞍钢节能公司网站开发陈仓网站建设
  • 手机网站怎样排版最好东莞常平招聘网最新招聘信息
  • 网站推广途径选择com域名和网站
  • 建设网站后如何上线免费的网站app下载
  • 哪些动物可以做网站名天津免费建站
  • 网站关键字优化技巧如何做推广麦当劳的网站
  • 广州公司注册场地要求网站怎么优化排名的方法
  • 自己做网站用什么软件建设银行网站联系电话
  • 做一个论坛网站需要多少钱推广型网站制作公司
  • 网站介绍页面网站建设怎么找客户资源
  • 我的百度网盘登录入口大兵seo博客
  • 注册监理工程师注册查询系统关于进一步优化 广州
  • 建设网站怎样挣钱网页设计培训班哪里好
  • 类似+wordpress+建站wordpress教程视频教程
  • wordpress多个网站百度识图扫一扫入口
  • 广州网站建设的费用网站建设外包必须注意几点
  • 蓬莱做网站公司辽宁省网站备案要求
  • 西安做网站价格女装标题优化关键词
  • 三门峡市建设局网站wordpress安装伪静态
  • 校园兼职网站开发用例图最厉害的搜索引擎
  • 企业网站seo哪里好10黄页网站建设