VUE3 UI 轮子

初始架构

vite 文档给出的命令是
npm init vite-app <project-name>
yarn create vite-app <project-name>
等价于
全局安装 create-vite-app 然后
cva <project-name>
等价于
npx createa-vite-app <project-name>
即 npx 会帮你全局安装用到的包

Vue 2 和 Vue 3 的区别

90% 的写法完全一致,除了以下几点
Vue 3 的 Template 支持多个根标签,Vue 2 不支持
Vue 3 有 createApp(),而 Vue 2 的是 new Vue()
createApp(组件),new Vue({template, render})


三个create分别对应内存型路由,Hash型路由和History型路由


Router类型参数:history和routes

菜单的隐藏和显示
搞一个asidevisible的变量,ture是显示 false是隐藏。放在app里面,放到其他地方无法访问,把asidevisible标记为所有后代都可以使用,让他的子组件都可以访问,用provide(‘xxx’,asideVisible)获取asideVisible,无论app和topnav之间有多少层组件,provide都可以访问到。在topnav和aside里面加一个inject( ).可以访问到asidevisible的值

解决switch组件的css动画,怎么才能让圆圈滑到右端

如果用动画,动画只可以改变过渡的值,不可以改变属性。所以
用calc()
value不仅可以表示初始状态,也可以表示更新后的状态

使用 :value 和 @input 让父子组件进行通信组件通信)和$event

Vue数据通信

内部通信:自产自销,只可以在内部
父子通信:值从别的组件得来的,需要改通过context.emit('update:xxx')告诉那个组件需要修改,改完了组件再把修改过后的值传回来
xxx必须和props { xxx:yyyyyyyyy}里声明的一致
emit(事件名,事件参数),///$event的值就是事件参数

使用 v-model

Vue 3 的v-model
要求:
属性名任意,假设为 x
事件名必须为 "update:x"
效果:
<Switch :value="y" @update:value="y = $event"/>
可以简写为:
<Switch v-model:value="y" />
文档
breaking change:https://v3.vuejs.org/guide/migration/v-model.html#using-v-bind-sync

value="true" 和 :value="true" 的区别
没有冒号是字符串 后面有冒号的是boolean

使用 CSS transition 添加过渡动画
使用 ref 可创建内部数据

框架就是把你框起来:不准改 props

Vue 2 和 Vue 3 的区别

新 v-model 代替以前的 v-model 和 .sync
新增 context.emit,与 this.emit 作用相同,共存 this.emit 可以在method里用
context.emit在setup( )里用、

Vue属性继承,默认属性传给根元素
inheritAttrs意思是继承属性,不想用的话可以用inheritAttrs:false 来禁用它,

… 扩展声明符 展示所有的属性,consolo.log的时候很好用

props和attrs,

1>props如果不声明,就什么都没有,要先声明才可以取值,attrs不用先声明,默认会收集值
2> props不包含事件,attrs包含事件
3>在props里没声明的东西,回自动跑到attrs里.
4>props可以声明string之外的类型,attrs只能支持atring类型。

UI库的CSS

不能使用 scoped,因为 data-v-xxx 中的 xxx 每次运行可能不同
必须输出稳定不变的 class 选择器,方便使用者覆盖
必须加前缀
.button 不行,如果使用者起名叫button,很容易被使用者覆盖。.gulu-button 可以,不太容易被覆盖
.theme-link 不行,很容易被使用者覆盖
.gulu-theme-link 可以,不太容易被覆盖
^=xxx 以xxx开头的 *= xxx 含有xxx字符段的

<template>里面还可以再写一个<template>!

Dialog 的值由visiable控制,但是visiable是外部传入的props,props不能更改!

emit没有返回值,没有返回值,没有返回值!事件不应该有返回值!

具名插槽用法:

在外面写上 <template v-slot:xxx>
在里面写上 <slot name="xxx">

CSS层级比较。需要看上级层级。
<Teleport to="xxx"> 请把我传送到xxx的下面,可以用于CSS层级

用JS获取插槽内容

const defaults = context.slots.default()

动态设置div的宽度

v-for里的高级用法,动态绑定ref
如果当前元素存在,就用divs里面的第i个等于el


官方文档

实际操作

  <div
          class="neko-tabs-nav-item"
          v-for="(t, index) in titles"
          :ref="el => { if (el) navItems[index] = el }"
          @click="select(t)"
          :class="{ selected: t === selected }"
          :key="index"
        >
export default {
 setup(props, context) {
    const navItems = ref < HTMLDivElement[] > ([])
}

ref后面的<>用来传TS的参数,这是TS的泛型语法,告诉TS,后面()里的数组类型是HTMLDiv,要在动态挂载后才可以查询到navItem的值,所以用onMounted,然后用filter去过滤,找到div里面的classList



看filter筛选结果里有没有用contains('属性名'),然后用getBoundingClientRect获取元素的宽度值,也就是导航一的宽度,
然后赋值给横线的宽度

const result = divs.filter(div => div.classList.contains('selected'))[0]
/////还可以这么写 
///const result = divs.find(div => div.classList.contains('selected'))[0]
////缺点就是一些古老的浏览器不支持find
const {width}=result.getBoundingClientRect()
 indicator.value.style.width=width+'px'

Vue3 WatchEffect 可以在值第一次变化是时候执行,值在后面变化的时候也执行,放在onMounted()里才不会有BUG


WatchEffect

ES 6 析构赋值的重命名语法

const { left: left1 } = x. getBoundingClientRect()
const { left: left2 } = y. getBoundingClientRect()

文档主页画圆弧

用border-radius: 100px 40px
用 clip-path:ellipse(80% 60% at 50% 40%)
https://developer.mozilla.org/en-US/docs/Web/CSS/clip-path

采用grid布局
如果router-ink被选中,vue自带属性 router-link-active 和router-link-exact-active
就可以加CSS啦

如何像官网一样展示源代码

需要用vue-loader的CustomBlocks

Vite截图

文档链接:https://vue-loader.vuejs.org/guide/custom-blocks.html

   Component.__sourceCode = ${
        JSON.stringify(main)
        }
        Component.__sourceCodeTitle = ${JSON.stringify(title)}
      }`.trim()

用法:在组件里写一个<demo> 检查的时候发现有<demo>标签,就把当前源代码除了<demo>标签之外的东西,放到当前组件__sourceCode里面

高亮源代码:用prismjs和v-html

一个花里胡哨的官网:https://prismjs.com/
引入的话不需要官网说的 import Prism from 'prismjs';
会报错。在prism.js文件里把这个prism声明成全局变量了

prism.js

项目build 之后不加载 md 文件

这是因为 rollup 不支持 import() 时动态读取路径(也就是拼字符串)
要么让它支持一下(不靠谱)
要么不要拼字符串 ✔ 在route.ts里把所有动态路由改成静态路由,就是让他事先加载好,然后在后面的md函数里直接引用

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容