Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Xavier-萧
VueJS-生命周期钩子
提交
f2c9350b
V
VueJS-生命周期钩子
项目概览
Xavier-萧
/
VueJS-生命周期钩子
与 Fork 源项目一致
Fork自
inscode / VueJS
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
VueJS-生命周期钩子
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
f2c9350b
编写于
7月 12, 2024
作者:
B
big_sun_962464
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fri Jul 12 11:32:00 CST 2024 inscode
上级
0c9f2f2b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
25 addition
and
91 deletion
+25
-91
src/App.vue
src/App.vue
+11
-90
src/components/Com1.vue
src/components/Com1.vue
+14
-1
未找到文件。
src/App.vue
浏览文件 @
f2c9350b
...
...
@@ -2,105 +2,26 @@
import
Com1
from
'
./components/Com1.vue
'
import
Com2
from
'
./components/Com2.vue
'
import
{
onMounted
,
toRefs
,
watchEffect
,
shallowReadonly
,
readonly
,
ref
,
reactive
,
shallowRef
,
computed
,
isRef
,
unref
,
toRef
,
toValue
,
watch
,
onBeforeMount
,
onBeforeUpdate
,
onUpdated
}
from
'
vue
'
// onBeforeMount(()=>{
// debugger
// console.log('onBeforeMount')
// })
// onMounted(()=>{
// debugger
// console.log('onMounted')
// })
// onBeforeUpdate(()=>{
// debugger
// console.log('onBeforeUpdate')
// })
// onUpdated(()=>{
// debugger
// console.log('onUpdated')
// })
const
obj
=
{
name
:
'
普通obj
'
const
tabs
=
{
Com1
,
Com2
}
const
msg
=
ref
(
"
你好!
"
)
const
refMsg
=
ref
({
msg
:
"
欢迎使用VUE3.0
"
})
const
shallowRefMsg
=
shallowRef
({
msg
:
"
欢迎使用VUE3.1
"
})
const
refObjMsg
=
ref
({
msg
:
ref
({
obj
:
ref
(
"
你好
"
)
})
})
console
.
log
(
msg
)
const
refCom
=
ref
({
name
:
'
Com1
'
,
com
:
Com1
const
currentObj
=
ref
({
tab
:
Com1
,
key
:
'
Com1
'
})
function
changeMsg
(){
// refMsg.value = 777
// refMsg.value.msg = 888
msg
.
value
+=
'
12
'
function
changeCom
(
k
,
v
){
currentObj
.
value
.
key
=
k
currentObj
.
value
.
tab
=
v
}
setTimeout
(()
=>
{
changeMsg
()
},
6000
);
function
changeShallowRefMsg
(){
// shallowRefMsg.value = 888
shallowRefMsg
.
value
.
msg
=
999
console
.
log
(
shallowRefMsg
)
}
function
useFeature
(
id
){
watch
(
()
=>
toValue
(
id
),
(
val
)
=>
{
console
.
log
(
77
,
val
)
}
)
}
function
changeCom
(){
if
(
refCom
.
value
.
name
===
'
Com1
'
){
refCom
.
value
.
name
=
'
Com2
'
refCom
.
value
.
com
=
Com2
}
else
{
refCom
.
value
.
name
=
'
Com1
'
refCom
.
value
.
com
=
Com1
}
}
useFeature
(
refMsg
)
const
reactiveObj
=
reactive
(
obj
)
console
.
log
(
reactiveObj
)
console
.
log
(
obj
)
console
.
log
(
reactiveObj
==
obj
)
watchEffect
(()
=>
{
document
.
body
.
innerHTML
=
`msg is:
${
msg
.
value
}
`
})
</
script
>
<
template
>
<p>
{{
refObjMsg
}}
</p>
<p>
{{
refMsg
}}
</p>
<button
@
click=
"changeMsg"
>
changeMsg
</button>
<p>
{{
shallowRefMsg
}}
</p>
<button
@
click=
"changeShallowRefMsg"
>
shallowRefMsg
</button>
<p>
<button
@
click=
"changeCom"
>
+-
</button>
</p>
<component
:is=
"refCom.com"
></component>
<button
v-for=
"(v,k) in tabs"
:key=
"k"
@
click=
"changeCom(k,v)"
>
{{
k
}}
</button>
<component
:is=
"currentObj.tab"
></component>
</
template
>
<
style
scoped
>
...
...
src/components/Com1.vue
浏览文件 @
f2c9350b
...
...
@@ -4,7 +4,20 @@
</div>
</
template
>
<
script
setup
lang=
"ts"
>
import
{
defineProps
,
computed
,
defineEmits
,
onActivated
,
onDeactivated
,
onBeforeUnmount
,
onUnmounted
}
from
'
vue
'
import
{
defineProps
,
computed
,
defineEmits
,
onActivated
,
onDeactivated
,
onBeforeUnmount
,
onUnmounted
,
onMounted
,
onUpdated
}
from
'
vue
'
onMounted
(()
=>
{
debugger
})
onUnmounted
(()
=>
{
debugger
})
onUpdated
(()
=>
{
debugger
})
onActivated
(()
=>
{
debugger
console
.
log
(
'
Com1-onActivated
'
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录