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

视频网站是用什么框架做的软件开发工程师就业前景

视频网站是用什么框架做的,软件开发工程师就业前景,在线做效果图有哪些网站有哪些,做网页学什么语言目录 一、创建vue3工程1. 使用vue-cli创建2.使用 vite 创建 二、setup使用三、ref函数四、reactive函数五、计算属性与监视属性5.1 computed函数5.2 watch函数5.3 watchEffect函数 六、自定义hook函数七、toRef函数八、shallowReactive 与 shallowRef九、readonly 与 shallowRe… 目录 一、创建vue3工程1. 使用vue-cli创建2.使用 vite 创建 二、setup使用三、ref函数四、reactive函数五、计算属性与监视属性5.1 computed函数5.2 watch函数5.3 watchEffect函数 六、自定义hook函数七、toRef函数八、shallowReactive 与 shallowRef九、readonly 与 shallowReadonly十、toRaw 与 markRaw十一、customRef十二、provide 与 inject十三、响应式数据的判断十四、新的组件14.1 Fragment14.2 Teleport14.3 Suspense 十五、其他15.1 全局API的转移15.2 其他改变 一、创建vue3工程 1. 使用vue-cli创建 ## 查看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 serve2.使用 vite 创建 ## 创建工程 npm init vite-app project-name ## 进入工程目录 cd project-name ## 安装依赖 npm install ## 运行 npm run dev二、setup使用 在 Vue3.0 中变量必须 return 出来 template 中才能使用而在 Vue3.2 中只需要在 script 标签上加上 setup 属性无需 return template 便可直接使用。 Vue3.0写法 scriptimport {ref} from vueexport default {name: App,setup(){//数据let name ref(张三)let age ref(18)let job ref({type:前端工程师,salary:30K})//方法function changeInfo(){console.log(job.value)}//返回一个对象常用return {name,age,job,changeInfo}}} /scriptVue3.2 setup写法(推荐使用) 只需在script标签中加入setup即可 template 便可直接使用定义的方法和属性 script setupimport {ref,reactive,toRefs,} from vueconst data reactive({patternVisible: false,debugVisible: false,aboutExeVisible: false,})const content ref(content)//使用toRefs解构const { patternVisible, debugVisible, aboutExeVisible } toRefs(data) /script 注意事项 1.可以和vue2配置混用但尽量不要与Vue2.x配置混用 2.setup不能是一个async函数因为返回值不再是return的对象, 而是promise, 模板看不到return对象中的属性。后期也可以返回一个Promise实例但需要Suspense和异步组件的配合 setup执行的时机 在beforeCreate之前执行一次this是undefined。 setup的参数 props值为对象包含组件外部传递过来且组件内部声明接收了的属性。context上下文对象 attrs: 值为对象包含组件外部传递过来但没有在props配置中声明的属性, 相当于 this.$attrs。slots: 收到的插槽内容, 相当于 this.$slots。emit: 分发自定义事件的函数, 相当于 this.$emit。 三、ref函数 作用: 定义一个响应式的数据语法: const xxx ref(initValue) 创建一个包含响应式数据的引用对象reference对象简称ref对象。JS中操作数据 xxx.value模板中读取数据: 不需要.value直接div{{xxx}}/div 备注 接收的数据可以是基本类型、也可以是对象类型。基本类型的数据响应式依然是靠Object.defineProperty()的get与set完成的。对象类型的数据内部 “ 求助 ” 了Vue3.0中的一个新函数—— reactive函数 templateh1一个人的信息/h1h2姓名{{name}}/h2h2年龄{{age}}/h2h3工作种类{{job.type}}/h3h3工作薪水{{job.salary}}/h3button clickchangeInfo修改人的信息/button /template scriptimport {ref} from vueexport default {name: App,setup(){//数据let name ref(张三)let age ref(18)let job ref({type:前端工程师,salary:30K})//方法function changeInfo(){console.log(job.value)}//返回一个对象常用return {name,age,job,changeInfo}}} /script四、reactive函数 作用: 定义一个对象类型的响应式数据基本类型不要用它要用ref函数语法let xxx reactive({})返回一个代理对象Proxy的实例对象简称proxy对象reactive定义的响应式数据是“深层次的”。内部基于 ES6 的 Proxy 实现通过代理对象操作源对象内部数据进行操作。 五、计算属性与监视属性 5.1 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]}}) }5.2 watch函数 注意点 监视reactive定义的响应式数据时oldValue无法正确获取、强制开启了深度监视deep配置失效。监视reactive定义的响应式数据中某个属性时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配置有效5.3 watchEffect函数 watch的套路是既要指明监视的属性也要指明监视的回调。watchEffect的套路是不用指明监视哪个属性监视的回调中用到哪个属性那就监视哪个属性。watchEffect有点像computed 但computed注重的计算出来的值回调函数的返回值所以必须要写返回值。而watchEffect更注重的是过程回调函数的函数体所以不用写返回值。 //watchEffect所指定的回调中用到的数据只要发生变化则直接重新执行回调。 watchEffect((){const x1 sum.valueconst x2 person.ageconsole.log(watchEffect配置的回调执行了) })六、自定义hook函数 什么是hook—— 本质是一个函数把setup函数中使用的Composition API进行了封装。类似于vue2.x中的mixin。自定义hook的优势: 复用代码, 让setup中的逻辑更清楚易懂。 第一步自定义usePoint.js函数代表一个hook函数 里面可以引入组合式api最后必须要有返回值 import {reactive,onMounted, onBeforeUnmount } from vue; export default (){let point reactive({x:0,y:0})function savePoint(e){point.x e.pageX;point.y e.pageY;console.log(e.pageX,e.pageY);}onMounted((){window.addEventListener(click,savePoint)})onBeforeUnmount((){window.removeEventListener(click,savePoint)})return point; }第二步引入自定义hook函数 import {ref } from vue;import usePoint from ../hooks/usePointexport default {name:Demo,setup() {let sum ref(0);let point usePoint();//返回一个对象(常用)return {sum,point}},}目录结构 七、toRef函数 作用创建一个 ref 对象其value值指向另一个对象中的某个属性。语法const name toRef(person,‘name’)应用: 要将响应式对象中的某个属性单独提供给外部使用时。扩展toRefs 与toRef功能一致但可以批量创建多个 ref 对象语法toRefs(person) import {reactive,toRef,toRefs} from vue; export default {name:Demo,setup() {let person reactive({name:张三,age:20,job:{j1:{salary:3000}}})// const name1 toRef(person,name);// console.log(name1);const x toRefs(person);console.log(x);八、shallowReactive 与 shallowRef shallowReactive只处理对象最外层属性的响应式浅响应式。shallowRef只处理基本数据类型的响应式, 不进行对象的响应式处理。什么时候使用? 如果有一个对象数据结构比较深, 但变化时只是外层属性变化 shallowReactive。如果有一个对象数据后续功能不会修改该对象中的属性而是生新的对象来替换 shallowRef。 九、readonly 与 shallowReadonly readonly: 让一个响应式数据变为只读的深只读。shallowReadonly让一个响应式数据变为只读的浅只读。应用场景: 不希望数据被修改时。 let person reactive({name:张三,age:20,job:{j1:{salary:3000}}}) let sum ref(0); // person readonly(person); //person shallowReadonly(person);//只考虑浅层的只读 sum readonly(sum);十、toRaw 与 markRaw toRaw 作用将一个由reactive生成的响应式对象转为普通对象。使用场景用于读取响应式对象对应的普通对象对这个普通对象的所有操作不会引起页面更新。 markRaw 作用标记一个对象使其永远不会再成为响应式对象。应用场景: 有些值不应被设置为响应式的例如复杂的第三方类库等。当渲染具有不可变数据源的大列表时跳过响应式转换可以提高性能。 let person reactive({name:张三,age:20,job:{j1:{salary:3000}}})function showRawPerson(){//只能处理reactive的对象const p toRaw(person);console.log(p);}function addCar(){let car {name:奔驰,price:1000}//不会变成响应式对象person.car markRaw(car);}十一、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}}} /script十二、provide 与 inject 作用实现祖与后代组件间通信套路父组件有一个 provide 选项来提供数据后代组件有一个 inject 选项来开始使用这些数据具体写法 1.祖组件中setup(){......let car reactive({name:奔驰,price:40万})provide(car,car)...... }2.后代组件中: setup(props,context){......const car inject(car)return {car}...... }十三、响应式数据的判断 isRef: 检查一个值是否为一个 ref 对象isReactive: 检查一个对象是否是由 reactive 创建的响应式代理isReadonly: 检查一个对象是否是由 readonly 创建的只读代理isProxy: 检查一个对象是否是由 reactive 或者 readonly 方法创建的代理 十四、新的组件 14.1 Fragment 在Vue2中: 组件必须有一个根标签在Vue3中: 组件可以没有根标签, 内部会将多个标签包含在一个Fragment虚拟元素中好处: 减少标签层级, 减小内存占用 14.2 Teleport 什么是Teleport—— Teleport 是一种能够将我们的组件html结构移动到指定位置的技术。to:移动的位置 teleport tobodydiv v-ifisShow classmaskdiv classdialogh3我是一个弹窗/h3h4一些内容/h4h4一些内容/h4h4一些内容/h4button clickisShowfalse关闭弹窗/button/div/div/teleport14.3 Suspense 等待异步组件时渲染一些额外内容让应用有更好的用户体验使用步骤 异步引入组件 import {defineAsyncComponent} from vueconst 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十五、其他 15.1 全局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上 15.2 其他改变 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
http://www.huolong8.cn/news/17712/

相关文章:

  • 注册网站请签署意见是写无怎么可以做网站的网站
  • 设计网站网站名称重庆网站制作福州
  • 网页网站开发设计工作前景网络营销方式名词解释
  • 滕州微信网站郑州网站建设哪家
  • 公司网站建设的申请wordpress mysql备份
  • 24小时自助建站行业网站有哪些平台
  • 网站建设制作设计公司wordpress禁止用户仪表盘
  • 做面包的公司网站麦进斗网站建设
  • 龙门石窟网站建设策划报告天津软件设计公司
  • 汕头 做网站哪个网站做加盟
  • 提高网站流量的软文案例seo外包公司兴田德润官方地址
  • 湖南网站seo营销多少费用wordpress无法删除插件_因为发生了错误:
  • 内蒙网站建设赫伟创意星空科技禅城南庄网站制作
  • 光谷网站建设公司智慧团建电脑版登录入口
  • 网站建设 智宇软件家居设计
  • 使用帝国备份王搬迁织梦网站做筹款的网站需要什么资质
  • 网站被黑解决方案优质手机网站建设哪家好
  • 江苏 江苏省住房和城乡建设厅网站成都网站建设推荐
  • 欧美模板网站建设如何建立国外网站
  • 汽车做网站做竞品分析的网站
  • 网站域名解析ip查询定制产品网站有哪些
  • 国内出色的网站建设公司对做网站有什么建议
  • 泸州住房城乡建设局官方网站html5网站开发实例书籍
  • 土石方工程网站郑州模板网站建设
  • 景德镇做网站公司网页广告
  • 汕头仿站定制模板建站网站建设步骤大全
  • 微信手机网站三合一国外网站需要备案吗
  • 公司网站建设手机端跟PC端张家港企业做网站
  • 山东网站营销seo哪家好在国外做h网站怎么样
  • 青山做网站进入公众号继续阅读下一章