Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello-uvue
提交
c107ce70
H
hello-uvue
项目概览
DCloud
/
hello-uvue
通知
342
Star
2
Fork
6
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
H
hello-uvue
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c107ce70
编写于
6月 30, 2023
作者:
crlfe
😲
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
增加组件实例示例
上级
97155cf5
变更
37
显示空白变更内容
内联
并排
Showing
37 changed file
with
982 addition
and
15 deletion
+982
-15
App.vue
App.vue
+1
-1
pages.json
pages.json
+79
-1
pages/component-instance/attrs/attrs.test.js
pages/component-instance/attrs/attrs.test.js
+5
-0
pages/component-instance/attrs/attrs.uvue
pages/component-instance/attrs/attrs.uvue
+35
-0
pages/component-instance/attrs/child.uvue
pages/component-instance/attrs/child.uvue
+43
-0
pages/component-instance/data/data.test.js
pages/component-instance/data/data.test.js
+26
-0
pages/component-instance/data/data.uvue
pages/component-instance/data/data.uvue
+52
-0
pages/component-instance/el/el.test.js
pages/component-instance/el/el.test.js
+5
-0
pages/component-instance/el/el.uvue
pages/component-instance/el/el.uvue
+28
-0
pages/component-instance/emit-function/child.uvue
pages/component-instance/emit-function/child.uvue
+20
-0
pages/component-instance/emit-function/emit-function.test.js
pages/component-instance/emit-function/emit-function.test.js
+5
-0
pages/component-instance/emit-function/emit-function.uvue
pages/component-instance/emit-function/emit-function.uvue
+44
-0
pages/component-instance/forceUpdate-function/forceUpdate-function.test.js
...nstance/forceUpdate-function/forceUpdate-function.test.js
+5
-0
pages/component-instance/forceUpdate-function/forceUpdate-function.uvue
...t-instance/forceUpdate-function/forceUpdate-function.uvue
+37
-0
pages/component-instance/nextTick-function/nextTick-function.test.js
...nent-instance/nextTick-function/nextTick-function.test.js
+5
-0
pages/component-instance/nextTick-function/nextTick-function.uvue
...mponent-instance/nextTick-function/nextTick-function.uvue
+33
-0
pages/component-instance/options/mixins.ts
pages/component-instance/options/mixins.ts
+12
-0
pages/component-instance/options/options.test.js
pages/component-instance/options/options.test.js
+5
-0
pages/component-instance/options/options.uvue
pages/component-instance/options/options.uvue
+43
-0
pages/component-instance/parent/child.uvue
pages/component-instance/parent/child.uvue
+27
-0
pages/component-instance/parent/parent.test.js
pages/component-instance/parent/parent.test.js
+5
-0
pages/component-instance/parent/parent.uvue
pages/component-instance/parent/parent.uvue
+34
-0
pages/component-instance/props/check-type.uvue
pages/component-instance/props/check-type.uvue
+87
-0
pages/component-instance/props/props.test.js
pages/component-instance/props/props.test.js
+5
-0
pages/component-instance/props/props.uvue
pages/component-instance/props/props.uvue
+48
-0
pages/component-instance/props/simple.uvue
pages/component-instance/props/simple.uvue
+42
-0
pages/component-instance/refs/child.uvue
pages/component-instance/refs/child.uvue
+17
-0
pages/component-instance/refs/refs.test.js
pages/component-instance/refs/refs.test.js
+5
-0
pages/component-instance/refs/refs.uvue
pages/component-instance/refs/refs.uvue
+31
-0
pages/component-instance/root/root.test.js
pages/component-instance/root/root.test.js
+5
-0
pages/component-instance/root/root.uvue
pages/component-instance/root/root.uvue
+30
-0
pages/component-instance/slots/slot.uvue
pages/component-instance/slots/slot.uvue
+26
-0
pages/component-instance/slots/slots.test.js
pages/component-instance/slots/slots.test.js
+5
-0
pages/component-instance/slots/slots.uvue
pages/component-instance/slots/slots.uvue
+30
-0
pages/component-instance/watch-function/watch-function.test.js
.../component-instance/watch-function/watch-function.test.js
+5
-0
pages/component-instance/watch-function/watch-function.uvue
pages/component-instance/watch-function/watch-function.uvue
+69
-0
pages/index.uvue
pages/index.uvue
+28
-13
未找到文件。
App.vue
浏览文件 @
c107ce70
pages.json
浏览文件 @
c107ce70
...
...
@@ -57,6 +57,84 @@
"style"
:
{
"navigationBarTitleText"
:
"page-lifecycle"
}
},
{
"path"
:
"pages/component-instance/data/data"
,
"style"
:
{
"navigationBarTitleText"
:
"$data"
}
},
{
"path"
:
"pages/component-instance/props/props"
,
"style"
:
{
"navigationBarTitleText"
:
"$props"
}
},
{
"path"
:
"pages/component-instance/el/el"
,
"style"
:
{
"navigationBarTitleText"
:
"$el"
}
},
{
"path"
:
"pages/component-instance/options/options"
,
"style"
:
{
"navigationBarTitleText"
:
"$options"
}
},
{
"path"
:
"pages/component-instance/parent/parent"
,
"style"
:
{
"navigationBarTitleText"
:
"$parent"
}
},
{
"path"
:
"pages/component-instance/root/root"
,
"style"
:
{
"navigationBarTitleText"
:
"$root"
}
},
{
"path"
:
"pages/component-instance/slots/slots"
,
"style"
:
{
"navigationBarTitleText"
:
"$slots"
}
},
{
"path"
:
"pages/component-instance/refs/refs"
,
"style"
:
{
"navigationBarTitleText"
:
"$refs"
}
},
{
"path"
:
"pages/component-instance/attrs/attrs"
,
"style"
:
{
"navigationBarTitleText"
:
"$attrs"
}
},
{
"path"
:
"pages/component-instance/watch-function/watch-function"
,
"style"
:
{
"navigationBarTitleText"
:
"$watch()"
}
},
{
"path"
:
"pages/component-instance/emit-function/emit-function"
,
"style"
:
{
"navigationBarTitleText"
:
"$emit()"
}
},
{
"path"
:
"pages/component-instance/forceUpdate-function/forceUpdate-function"
,
"style"
:
{
"navigationBarTitleText"
:
"$forceUpdate()"
}
},
{
"path"
:
"pages/component-instance/nextTick-function/nextTick-function"
,
"style"
:
{
"navigationBarTitleText"
:
"$nextTick()"
}
}
],
"globalStyle"
:
{
...
...
pages/component-instance/attrs/attrs.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/attrs/attrs
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/attrs/attrs.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<child
class="child-class"
style="color: red;"
id="child-id"
data-id="data-id"
val="val"
@result="() => {}"
name="child"
></child>
</view>
</template>
<script lang="ts">
import child from './child.uvue'
export default {
components: {
child
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/attrs/child.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view>
<view class="row">
<text>hasPropsAttrs</text>
<text>{{ hasPropsAttrs }}</text>
</view>
<view class="row">
<text>hasEmitsAttr</text>
<text>{{ hasEmitsAttr }}</text>
</view>
<view class="row">
<text>hasAttrs</text>
<text>{{ hasAttrs }}</text>
</view>
</view>
</template>
<script lang="ts">
export default {
emits: ['result'],
props: {
val: {
type: String,
default: "default value"
}
},
computed: {
hasPropsAttrs (): boolean {
return this.$attrs.has('val')
},
hasEmitsAttr (): boolean {
return this.$attrs.has('result')
},
hasAttrs (): boolean {
return this.$attrs.has('class')
}
}
}
</script>
<style scoped>
</style>
pages/component-instance/data/data.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/data/data
'
describe
(
'
$data
'
,
()
=>
{
let
page
beforeAll
(
async
()
=>
{
page
=
await
program
.
reLaunch
(
PAGE_PATH
)
await
page
.
waitFor
(
500
)
})
it
(
'
should data.val === 2
'
,
async
()
=>
{
const
plusButton
=
await
page
.
$
(
'
.plus
'
)
await
plusButton
.
tap
()
const
val
=
await
page
.
$
(
'
.val
'
)
expect
(
await
val
.
text
()).
toBe
(
'
2
'
)
});
it
(
'
should data.val === 1
'
,
async
()
=>
{
const
minusButton
=
await
page
.
$
(
'
.minus
'
)
await
minusButton
.
tap
()
const
val
=
await
page
.
$
(
'
.val
'
)
expect
(
await
val
.
text
()).
toBe
(
'
1
'
)
})
})
pages/component-instance/data/data.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">初始值: <text>1</text></view>
<view class="row">data.val: <text class="val">{{val}}</text></view>
<view class="row">data._val: <text class="_val">{{_val}}</text></view>
<view class="row">data.$val: <text class="$val">{{$val}}</text></view>
<view class="buttons">
<button class="btn plus" @click="click(1)">增加</button>
<button class="btn minus" @click="click(-1)">减少</button>
</view>
</view>
</template>
<script lang="ts">
export default {
data () {
return {
val: 1,
_val: 1,
$val: 1
}
},
methods: {
click (num: number) {
this.val += num
this._val += num
this.$val += num
}
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
.buttons {
display: flex;
flex-direction: row;
margin-top: 10px;
}
.btn {
flex: 1;
margin: 0 5px;
}
</style>
pages/component-instance/el/el.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/el/el.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<text class="child">root node tagName:</text>
<text class="tag-name">{{el}}</text>
</view>
</template>
<script lang="ts">
export default {
data () {
return {
el: ''
}
},
mounted () {
this.el = this.$el?.nodeName ?? "unknown"
}
}
</script>
<style>
.page {
font-size: 16px;
display: flex;
flex-direction: row;
justify-content: space-between;
}
</style>
pages/component-instance/emit-function/child.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view>
<button @click="click">调用父组件事件</button>
</view>
</template>
<script lang="ts">
export default {
emits: ['callback'],
methods: {
click () {
this.$emit('callback', 'string', `${Date.now()}`)
}
}
}
</script>
<style scoped>
</style>
pages/component-instance/emit-function/emit-function.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/emit-function/emit-function.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">
<text>子组件传的参数</text>
<text>
{{ value }}
</text>
</view>
<child @callback="callback"></child>
</view>
</template>
<script lang="ts">
import child from './child.uvue'
export default {
components: {
child
},
data () {
return {
value: [] as string[]
}
},
methods: {
callback (str: string, str1: string) {
this.value = [str, str1]
}
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/forceUpdate-function/forceUpdate-function.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/forceUpdate-function/forceUpdate-function.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">
<text>不支持 $forceUpdate()</text>
</view>
</view>
</template>
<script lang="ts">
type Obj = {
key: string
}
export default {
data () {
return {
// obj: {} as Obj
}
},
mounted () {
// this.obj.key = 'value'
// console.log(this.$forceUpdate)
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/nextTick-function/nextTick-function.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/nextTick-function/nextTick-function.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">
<text ref="text">{{value}}</text>
</view>
</view>
</template>
<script lang="ts">
type Obj = {
key: string
}
export default {
data () {
return {
value: 0
}
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/options/mixins.ts
0 → 100644
浏览文件 @
c107ce70
export
default
{
data
()
{
return
{
type
:
'
minix
'
}
},
methods
:
{
minixMethod
()
{
return
"
minixMethod
"
}
}
}
pages/component-instance/options/options.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/options/options.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">
<text>name: </text>
<text>{{name}}</text>
</view>
</view>
</template>
<script lang="ts">
// import mixins from "./mixins";
export default {
// mixins: [mixins],
name: "$options",
customKey: "customValue",
data () {
return {
name: "",
customKey: ""
}
},
mounted () {
this.name = this.$options.name
},
methods: {
// getCustomKey (): string {
// return this.$options.customKey
// }
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/parent/child.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="child">
<view>{{value}}</view>
</view>
</template>
<script lang="ts">
export default {
data () {
return {
value: "child"
}
},
mounted () {
this.value = this.$parent!.$data['value'] as string
},
methods: {
testFunction (): string {
return this.$parent!.$callMethod('testFunction') as string
}
}
}
</script>
<style scoped>
</style>
pages/component-instance/parent/parent.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/parent/parent.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<child></child>
</view>
</template>
<script lang="ts">
import child from './child.uvue'
export default {
components: {
child
},
data () {
return {
value: "parent"
}
},
methods: {
testFunction (): string {
return "parentFunctionResult"
}
}
}
</script>
<style>
.page {
font-size: 16px;
display: flex;
flex-direction: row;
justify-content: space-between;
}
</style>
pages/component-instance/props/check-type.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="component">
<view class="row">
<text>string: </text><text>{{str}}</text>
</view>
<view class="row">
<text>num: </text><text>{{num}}</text>
</view>
<view class="row">
<text>bool: </text><text>{{bool}}</text>
</view>
<!-- <view class="row">-->
<!-- <text>arr: </text>-->
<!-- [<text v-for="text in arr">{{text}},</text>]-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>obj.key: </text><text>{{obj.key}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>obj.key: </text><text>{{obj.key}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>date timestamp: </text><text>{{date.now()}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>function result: </text><text>{{func()}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>symbol: </text><text>{{symbol}}</text>-->
<!-- </view>-->
</view>
</template>
<script lang="ts">
type IProps = {
str: string
}
export default {
props: {
str: {
type: String,
default: 'default value'
},
num: {
type: Number,
default: 0
},
bool: {
type: Boolean,
default: false
},
// arr: {
// type: Array,
// default: (): Array<string> => {
// return []
// }
// },
// obj: {
// type: Object,
// default: () => {
// return {}
// }
// },
// date: {
// type: Date,
// default: () => {
// return new Date()
// }
// },
// func: {
// type: Function,
// default: () => {
// return () => {}
// }
// },
// symbol: {
// type: Symbol,
// default: Symbol('default')
// },
}
}
</script>
<style scoped>
</style>
pages/component-instance/props/props.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/props/props.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<check-type
str="abcd"
:num="12345"
:bool="true"
></check-type>
<!-- <view>简易类型</view>-->
<!-- <simple-->
<!-- str="abcd"-->
<!-- :num="12345"-->
<!-- :bool="true"-->
<!-- ></simple>-->
</view>
</template>
<script lang="ts">
import checkType from "./check-type.uvue";
// import simple from "./simple.uvue";
export default {
components: {
checkType,
// simple
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
.buttons {
display: flex;
flex-direction: row;
margin-top: 10px;
}
.btn {
flex: 1;
margin: 0 5px;
}
</style>
pages/component-instance/props/simple.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="component">
<view class="row">
<text>string: </text><text>{{str}}</text>
</view>
<view class="row">
<text>num: </text><text>{{num}}</text>
</view>
<view class="row">
<text>bool: </text><text>{{bool}}</text>
</view>
<!-- <view class="row">-->
<!-- <text>arr: </text>-->
<!-- [<text v-for="text in arr">{{text}},</text>]-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>obj.key: </text><text>{{obj.key}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>obj.key: </text><text>{{obj.key}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>date timestamp: </text><text>{{date.now()}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>function result: </text><text>{{func()}}</text>-->
<!-- </view>-->
<!-- <view class="row">-->
<!-- <text>symbol: </text><text>{{symbol}}</text>-->
<!-- </view>-->
</view>
</template>
<script lang="ts">
type IProps = {
str: string
}
export default {
props: ['str', 'num', 'bool'],
}
</script>
pages/component-instance/refs/child.uvue
0 → 100644
浏览文件 @
c107ce70
<script>
export default {
data () {
return {
value: "child value"
}
}
}
</script>
<template>
</template>
<style scoped>
</style>
pages/component-instance/refs/refs.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/refs/refs.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view ref="node">NodeRef</view>
<!-- <child ref="component">ComponentRef</child>-->
</view>
</template>
<script lang="ts">
// import child from './child.uvue'
export default {
// components: {
// child
// },
mounted () {
console.log(this.$refs)
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/root/root.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/root/root.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">rootIsApp: <text>{{isApp}}</text></view>
</view>
</template>
<script lang="ts">
export default {
data () {
return {
isApp: false
}
},
mounted () {
// this.isApp = this.$root.app
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/slots/slot.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view>
<slot name="header"></slot>
<slot name="footer"></slot>
</view>
</template>
<script lang="ts">
export default {
mounted () {
console.log(this.hasSlots())
},
methods: {
hasSlots (): boolean {
const header = this.$slots.get('header')
const footer = this.$slots.get('footer')
return header !== null && footer !== null
}
}
}
</script>
<style scoped>
</style>
pages/component-instance/slots/slots.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/slots/slots.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<slot-comp>
<template v-slot:header>header</template>
<template v-slot:footer>footer</template>
</slot-comp>
</view>
</template>
<script lang="ts">
import slot from './slot.uvue'
export default {
components: {
slotComp: slot
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/component-instance/watch-function/watch-function.test.js
0 → 100644
浏览文件 @
c107ce70
const
PAGE_PATH
=
'
/pages/component-instance/props/props
'
describe
(
'
$props
'
,
()
=>
{
})
pages/component-instance/watch-function/watch-function.uvue
0 → 100644
浏览文件 @
c107ce70
<template>
<view class="page">
<view class="row">
<text>初始值</text>
<text>init</text>
</view>
<view class="row">
<text>val</text>
<text>{{ val }}</text>
</view>
<view class="row">
<text>值是否变化</text>
<text>{{ changed }}</text>
</view>
</view>
</template>
<script lang="ts">
function sleep(timer: number = 1000, cb: () => void): void {
setTimeout(() => {
cb()
}, timer)
}
export default {
data() {
return {
val: "init",
changed: false,
a: 'a',
b: 'b',
// abChanged: false
}
},
mounted() {
this.createWatch()
// this.createGetterWatch()
},
methods: {
createWatch() {
this.$watch('val', () => {
this.changed = !this.changed
})
this.val = 'changed'
},
// createGetterWatch () {
// this.$watch(() => this.a + this.b, () => {
// this.abChanged = !this.abChanged
// })
//
// this.a = 'changed'
// }
}
}
</script>
<style>
.page {
font-size: 16px;
}
.row {
display: flex;
flex-direction: row;
justify-content: space-between;
margin-bottom: 10px;
}
</style>
pages/index.uvue
浏览文件 @
c107ce70
...
...
@@ -6,8 +6,8 @@
<!-- <text class="uni-panel-icon uni-icon" :class="item.open ? 'uni-panel-icon-on' : ''">{{item.open ? '' : ''}}</text> -->
</view>
<view class="uni-panel-c" v-if="item.open">
<view class="uni-navigate-item" v-for="
(page,key) in item.pages" :key="key
" @click="goDetailPage(page)">
<text class="uni-navigate-text">{{page}}</text>
<view class="uni-navigate-item" v-for="
page in item.pages" :key="page.name
" @click="goDetailPage(page)">
<text class="uni-navigate-text">{{page
.name
}}</text>
<!-- <text class="uni-navigate-icon uni-icon"></text> -->
</view>
</view>
...
...
@@ -24,7 +24,22 @@
id : string,
name : string,
open : boolean,
pages : string[]
pages : IListPageItem[]
}
type IListPageItem = {
name: string
path: string
}
function createPageItem (parent: string | null = null): (page: string) => IListPageItem {
return function (page: string): IListPageItem {
const routeName = page.replace(/\$/g, '').replace('()', '-function')
return {
name: page,
path: parent !== null ? `/pages/${parent}/${routeName}/${routeName}`: `/pages/${routeName}/${routeName}`
} as IListPageItem
}
}
export default {
...
...
@@ -36,8 +51,8 @@
name: '生命周期',
open: false,
pages: [
'page-lifecycle'
,
]
'page-lifecycle'
]
.map(createPageItem())
},
{
id: 'directives',
...
...
@@ -55,7 +70,7 @@
'v-once',
// 'v-memo',
// 'v-cloak'
]
]
.map(createPageItem())
},
{
id: 'state',
...
...
@@ -67,13 +82,13 @@
'computed',
'methods',
'watch'
]
]
.map(createPageItem('state'))
},
{
id: 'rendering',
name: '渲染选项',
open: false,
pages: ['template', 'render', 'slots']
pages: ['template', 'render', 'slots']
.map(createPageItem('rendering'))
},
{
id: 'component-instance',
...
...
@@ -93,7 +108,7 @@
'$emit()',
'$forceUpdate()',
'$nextTick()'
]
]
.map(createPageItem('component-instance'))
},
{
id: 'composition',
...
...
@@ -104,7 +119,7 @@
'inject',
'mixins',
'extends'
]
]
.map(createPageItem('composition'))
}
] as ListItem[]
}
...
...
@@ -145,9 +160,9 @@
// data: storageData
// })
},
goDetailPage(e :
string
) {
goDetailPage(e :
IListPageItem
) {
uni.navigateTo({
url:
`/pages/${e}/${e}`
url:
e.path
})
},
getLifeCycleNum(): number {
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录