提交 ff3ad10b 编写于 作者: D DCloud_LXH

feat(component): 调整 sidebar、新增组件

上级 2ec19efe
* [概述](README.md)
* [公共属性和事件](common.md)
* 内置组件```{"collapsable": false}```
* [view](view.md)
* [scroll-view](scroll-view.md)
* [nested-scroll](nested-scroll.md)
* [list-view](list-view.md)
* [sticky](sticky.md)
* [swiper](swiper.md)
* [navigator](navigator.md)
* [text](text.md)
* [rich-text](rich-text.md)
* [image](image.md)
* [input](input.md)
* [textarea](textarea.md)
* [button](button.md)
* [checkbox](checkbox-group.md)
* [radio](radio-group.md)
* [picker-view](picker-view.md)
* [progress](progress.md)
* [slider](slider.md)
* [switch](switch.md)
* [form](form.md)
* [canvas](canvas.md)
* [video](video.md)
* 视图容器
* [基本视图容器](view.md)
* [可滚动视图容器](scroll-view.md)
* 滑块视图容器
* [滑块视图容器](swiper.md)
* [swiper-item](swiper-item.md)
* [match-media](match-media.md)
* [可拖动区域](movable-area.md)
* [可移动的视图容器](movable-view.md)
* [cover-view](cover-view.md)
* [cover-image](cover-image.md)
* 列表组件
* [列表组件](list-view.md)
* [list-item](list-item.md)
* sticky
* [吸顶布局容器](sticky-header.md)
* [吸顶布局容器](sticky-section.md)
* nested-scroll
* [nested-scroll-header](nested-scroll-header.md)
* [nested-scroll-body](nested-scroll-body.md)
* 基础内容
* [图标](icon.md)
* [文本](text.md)
* [富图标](rich-text.md)
* [进度条](progress.md)
* 表单组件
* [按钮](button.md)
* 多选框
* [多选框组](checkbox-group.md)
* [多选框](checkbox.md)
* [表单](form.md)
* [输入框](input.md)
* [富文本编辑器](editor.md)
* [label](label.md)
* [底部弹出的滚动选择器](picker.md)
* 嵌入页面的滚动选择器
* [嵌入页面的滚动选择器](picker-view.md)
* [picker-view-column](picker-view-column.md)
* 单选项
* [单选组](radio-group.md)
* [单选项](radio.md)
* [滑动选择器](slider.md)
* [开关选择器](switch.md)
* [多行输入框](textarea.md)
* 导航
* [页面链接](navigator.md)
* 媒体组件
* [音频](audio.md)
* [图片](image.md)
* [视频](video.md)
* live
* [live-player](live-player.md)
* [live-pusher](live-pusher.md)
* 地图
* [地图](map.md)
* 画布
* [画布](canvas.md)
* 网页
* [web-view](web-view.md)
* [animation-view](animation-view.md)
* 页面属性配置节点
* [page-meta](page-meta.md)
* [navigation-bar](navigation-bar.md)
* [custom-tab-bar](custom-tab-bar.md)
* unicloud
* [unicloud-db](unicloud-db.md)
* [animation-view](animation-view.md)
* [其他组件](unsupport.md)
## audio
<!-- UTSCOMJSON.audio.description -->
<!-- UTSCOMJSON.audio.compatibility -->
<!-- UTSCOMJSON.audio.attribute -->
<!-- UTSCOMJSON.audio.event -->
<!-- UTSCOMJSON.audio.component_type -->
<!-- UTSCOMJSON.audio.children -->
<!-- UTSCOMJSON.audio.example -->
<!-- UTSCOMJSON.audio.reference -->
......@@ -17,22 +17,3 @@
<!-- UTSCOMJSON.checkbox-group.example -->
<!-- UTSCOMJSON.checkbox-group.reference -->
## checkbox
<!-- UTSCOMJSON.checkbox.description -->
<!-- UTSCOMJSON.checkbox.compatibility -->
<!-- UTSCOMJSON.checkbox.attribute -->
<!-- UTSCOMJSON.checkbox.event -->
<!-- UTSCOMJSON.checkbox.component_type-->
<!-- UTSCOMJSON.checkbox.children -->
<!-- UTSCOMJSON.checkbox.example -->
<!-- UTSCOMJSON.checkbox.reference -->
## checkbox
<!-- UTSCOMJSON.checkbox.description -->
<!-- UTSCOMJSON.checkbox.compatibility -->
<!-- UTSCOMJSON.checkbox.attribute -->
<!-- UTSCOMJSON.checkbox.event -->
<!-- UTSCOMJSON.checkbox.component_type -->
<!-- UTSCOMJSON.checkbox.children -->
<!-- UTSCOMJSON.checkbox.example -->
<!-- UTSCOMJSON.checkbox.reference -->
## cover-image
<!-- UTSCOMJSON.cover-image.description -->
<!-- UTSCOMJSON.cover-image.compatibility -->
<!-- UTSCOMJSON.cover-image.attribute -->
<!-- UTSCOMJSON.cover-image.event -->
<!-- UTSCOMJSON.cover-image.component_type -->
<!-- UTSCOMJSON.cover-image.children -->
<!-- UTSCOMJSON.cover-image.example -->
<!-- UTSCOMJSON.cover-image.reference -->
## cover-view
<!-- UTSCOMJSON.cover-view.description -->
<!-- UTSCOMJSON.cover-view.compatibility -->
<!-- UTSCOMJSON.cover-view.attribute -->
<!-- UTSCOMJSON.cover-view.event -->
<!-- UTSCOMJSON.cover-view.component_type -->
<!-- UTSCOMJSON.cover-view.children -->
<!-- UTSCOMJSON.cover-view.example -->
<!-- UTSCOMJSON.cover-view.reference -->
## custom-tab-bar
<!-- UTSCOMJSON.custom-tab-bar.description -->
<!-- UTSCOMJSON.custom-tab-bar.compatibility -->
<!-- UTSCOMJSON.custom-tab-bar.attribute -->
<!-- UTSCOMJSON.custom-tab-bar.event -->
<!-- UTSCOMJSON.custom-tab-bar.component_type -->
<!-- UTSCOMJSON.custom-tab-bar.children -->
<!-- UTSCOMJSON.custom-tab-bar.example -->
<!-- UTSCOMJSON.custom-tab-bar.reference -->
## editor
<!-- UTSCOMJSON.editor.description -->
<!-- UTSCOMJSON.editor.compatibility -->
<!-- UTSCOMJSON.editor.attribute -->
<!-- UTSCOMJSON.editor.event -->
<!-- UTSCOMJSON.editor.component_type -->
<!-- UTSCOMJSON.editor.children -->
<!-- UTSCOMJSON.editor.example -->
<!-- UTSCOMJSON.editor.reference -->
## icon
<!-- UTSCOMJSON.icon.description -->
<!-- UTSCOMJSON.icon.compatibility -->
<!-- UTSCOMJSON.icon.attribute -->
<!-- UTSCOMJSON.icon.event -->
<!-- UTSCOMJSON.icon.component_type -->
<!-- UTSCOMJSON.icon.children -->
<!-- UTSCOMJSON.icon.example -->
<!-- UTSCOMJSON.icon.reference -->
## label
<!-- UTSCOMJSON.label.description -->
<!-- UTSCOMJSON.label.compatibility -->
<!-- UTSCOMJSON.label.attribute -->
<!-- UTSCOMJSON.label.event -->
<!-- UTSCOMJSON.label.component_type -->
<!-- UTSCOMJSON.label.children -->
<!-- UTSCOMJSON.label.example -->
<!-- UTSCOMJSON.label.reference -->
## list-item
<!-- UTSCOMJSON.list-item.description -->
<!-- UTSCOMJSON.list-item.compatibility -->
<!-- UTSCOMJSON.list-item.attribute -->
### list-item复用机制
> 仅App平台支持复用。Web平台仅渲染当前屏幕及上下一定高度内的元素,没有对list-item进行复用。
+ type属性定义list-item组件类型。不赋值type属性默认值为0,每一个type类型都会有对应的list-item组件缓存池。
+ list-view组件加载list-item组件时,会优先查询对应type缓存池是否存在可复用的list-item组件。有则复用没有则创建新的list-item组件。
+ list-item组件被滑动出屏幕则会优先添加到对应类型的list-item缓存池,每个类型缓存最大5个(不同平台缓存最大值不固定),如果缓存池已满则进行组件销毁!
+ 部分list-item组件存在子元素个数差异或排版差异时。请尽可能的配置不同的type,这样可以规避获取相同type类型的list-item组件后。
* 很常见的一个错误是在长列表上方的list-item里放置banner图,却没有为这个不可复用的list-item设置单独的type,这会导致图片在复用失败后无法渲染。
* 由于子元素差异导致list-item无法正常复用问题。具体可参考示例:
```html
<template>
<view class="content">
<list-view ref="listView" class="list" :scroll-y="true">
<list-item v-for="(item,index) in list" :key="index" class="content-item1" type=1>
<text class="text">title-{{item}}</text>
<text class="text">content-{{item}}</text>
</list-item>
<list-item v-for="(item,index) in list" :key="index" class="content-item2" type=2>
<image class="image" src ="/static/test-image/logo.png"></image>
</list-item>
<list-item type=3>
<text class="loading">{{text}}</text>
</list-item>
</list-view>
</view>
</template>
```
示例中有三种类型的list-item组件。如果都不赋值type,list-item组件滑动出屏幕后都归类到type=0的缓存池。当触发list-item组件重新加载时,获取type=0的缓存池的组件,获取到的list-item组件可能是两个text子组件也可能是一个image子组件或一个text子组件,底层复用判断时则认为该情况异常不复用,重新创建新的list-item组件!复用失败未能优化性能。正确的方式则是不同的类型设置不同的type。加载时则会获取对应type类型缓存池中的list-item组件实现复用。
**注意:**
1. 避免对list-item组件的子元素设置event事件,复用后list-item组件部分子元素可能无法正常响应event,有相关业务需要对子元素设置event事件,可对list-item组件设置独立的type实现不复用。
<!-- UTSCOMJSON.list-item.event -->
<!-- UTSCOMJSON.list-item.component_type-->
<!-- UTSCOMJSON.list-item.children -->
<!-- UTSCOMJSON.list-item.example -->
<!-- UTSCOMJSON.list-item.reference -->
#### App平台
+ App平台scroll-x、scroll-y属性不支持同时设置为true,同时设置true时仅scroll-y生效。4.0版本开始scroll-x、scroll-y已废弃,请使用direction属性。
+ App平台list-view组件默认高度取值:
- list-view组件的子元素高度之和未超过list-view组件的父元素高度:
+ list-view组件的默认高度取值为子元素高度之和
- list-view组件的子元素高度之和超过list-view组件的父元素高度:
+ 3.9版本list-view组件默认高度取值为list-view组件父元素的高度。子元素高度之和超过list-view组件的高度,list-view组件可滚动。
+ 4.0版本开始list-view组件的默认高度取值为子元素高度之和。高度相同list-view组件无法滚动。开发者需要设置css属性定义list-view组件高度,让list-view组件高度小于子元素高度之和,实现滚动能力。
#### Web平台
+ web平台仅渲染当前屏幕及上下一定距离的内容,滚动高度为空白容器占位,因此如果使用dom API获取list-item内的元素可能无法取到。
+ scroll-with-animation属性在safari 15.4以下版本不支持
+ 尽量避免在list-item上使用浏览器的[外边距折叠特性](https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_box_model/Mastering_margin_collapsing)会导致list-view无法准确计算回收的元素的高度,进而导致滚动出现异常。即不要同时为list-item设置上边距(margin-top)和下边距(margin-bottom)。
......@@ -59,76 +59,6 @@ scroll-view开启嵌套模式后,list-view 可作为内层滚动视图与外
<!-- UTSCOMJSON.list-view.reference -->
## list-item
<!-- UTSCOMJSON.list-item.description -->
<!-- UTSCOMJSON.list-item.compatibility -->
<!-- UTSCOMJSON.list-item.attribute -->
### list-item复用机制
> 仅App平台支持复用。Web平台仅渲染当前屏幕及上下一定高度内的元素,没有对list-item进行复用。
+ type属性定义list-item组件类型。不赋值type属性默认值为0,每一个type类型都会有对应的list-item组件缓存池。
+ list-view组件加载list-item组件时,会优先查询对应type缓存池是否存在可复用的list-item组件。有则复用没有则创建新的list-item组件。
+ list-item组件被滑动出屏幕则会优先添加到对应类型的list-item缓存池,每个类型缓存最大5个(不同平台缓存最大值不固定),如果缓存池已满则进行组件销毁!
+ 部分list-item组件存在子元素个数差异或排版差异时。请尽可能的配置不同的type,这样可以规避获取相同type类型的list-item组件后。
* 很常见的一个错误是在长列表上方的list-item里放置banner图,却没有为这个不可复用的list-item设置单独的type,这会导致图片在复用失败后无法渲染。
* 由于子元素差异导致list-item无法正常复用问题。具体可参考示例:
```html
<template>
<view class="content">
<list-view ref="listView" class="list" :scroll-y="true">
<list-item v-for="(item,index) in list" :key="index" class="content-item1" type=1>
<text class="text">title-{{item}}</text>
<text class="text">content-{{item}}</text>
</list-item>
<list-item v-for="(item,index) in list" :key="index" class="content-item2" type=2>
<image class="image" src ="/static/test-image/logo.png"></image>
</list-item>
<list-item type=3>
<text class="loading">{{text}}</text>
</list-item>
</list-view>
</view>
</template>
```
示例中有三种类型的list-item组件。如果都不赋值type,list-item组件滑动出屏幕后都归类到type=0的缓存池。当触发list-item组件重新加载时,获取type=0的缓存池的组件,获取到的list-item组件可能是两个text子组件也可能是一个image子组件或一个text子组件,底层复用判断时则认为该情况异常不复用,重新创建新的list-item组件!复用失败未能优化性能。正确的方式则是不同的类型设置不同的type。加载时则会获取对应type类型缓存池中的list-item组件实现复用。
**注意:**
1. 避免对list-item组件的子元素设置event事件,复用后list-item组件部分子元素可能无法正常响应event,有相关业务需要对子元素设置event事件,可对list-item组件设置独立的type实现不复用。
<!-- UTSCOMJSON.list-item.event -->
<!-- UTSCOMJSON.list-item.component_type-->
<!-- UTSCOMJSON.list-item.children -->
<!-- UTSCOMJSON.list-item.example -->
<!-- UTSCOMJSON.list-item.reference -->
#### App平台
+ App平台scroll-x、scroll-y属性不支持同时设置为true,同时设置true时仅scroll-y生效。4.0版本开始scroll-x、scroll-y已废弃,请使用direction属性。
+ App平台list-view组件默认高度取值:
- list-view组件的子元素高度之和未超过list-view组件的父元素高度:
+ list-view组件的默认高度取值为子元素高度之和
- list-view组件的子元素高度之和超过list-view组件的父元素高度:
+ 3.9版本list-view组件默认高度取值为list-view组件父元素的高度。子元素高度之和超过list-view组件的高度,list-view组件可滚动。
+ 4.0版本开始list-view组件的默认高度取值为子元素高度之和。高度相同list-view组件无法滚动。开发者需要设置css属性定义list-view组件高度,让list-view组件高度小于子元素高度之和,实现滚动能力。
#### Web平台
+ web平台仅渲染当前屏幕及上下一定距离的内容,滚动高度为空白容器占位,因此如果使用dom API获取list-item内的元素可能无法取到。
+ scroll-with-animation属性在safari 15.4以下版本不支持
+ 尽量避免在list-item上使用浏览器的[外边距折叠特性](https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_box_model/Mastering_margin_collapsing)会导致list-view无法准确计算回收的元素的高度,进而导致滚动出现异常。即不要同时为list-item设置上边距(margin-top)和下边距(margin-bottom)。
## 示例代码
- 联网联表:[https://gitcode.net/dcloud/hello-uni-app-x/-/blob/master/pages/template/list-news/list-news.uvue](https://gitcode.net/dcloud/hello-uni-app-x/-/blob/master/pages/template/list-news/list-news.uvue)
......
## live-player
<!-- UTSCOMJSON.live-player.description -->
<!-- UTSCOMJSON.live-player.compatibility -->
<!-- UTSCOMJSON.live-player.attribute -->
<!-- UTSCOMJSON.live-player.event -->
<!-- UTSCOMJSON.live-player.component_type -->
<!-- UTSCOMJSON.live-player.children -->
<!-- UTSCOMJSON.live-player.example -->
<!-- UTSCOMJSON.live-player.reference -->
## live-pusher
<!-- UTSCOMJSON.live-pusher.description -->
<!-- UTSCOMJSON.live-pusher.compatibility -->
<!-- UTSCOMJSON.live-pusher.attribute -->
<!-- UTSCOMJSON.live-pusher.event -->
<!-- UTSCOMJSON.live-pusher.component_type -->
<!-- UTSCOMJSON.live-pusher.children -->
<!-- UTSCOMJSON.live-pusher.example -->
<!-- UTSCOMJSON.live-pusher.reference -->
## map
<!-- UTSCOMJSON.map.description -->
<!-- UTSCOMJSON.map.compatibility -->
<!-- UTSCOMJSON.map.attribute -->
<!-- UTSCOMJSON.map.event -->
<!-- UTSCOMJSON.map.component_type -->
<!-- UTSCOMJSON.map.children -->
<!-- UTSCOMJSON.map.example -->
<!-- UTSCOMJSON.map.reference -->
## match-media
<!-- UTSCOMJSON.match-media.description -->
<!-- UTSCOMJSON.match-media.compatibility -->
<!-- UTSCOMJSON.match-media.attribute -->
<!-- UTSCOMJSON.match-media.event -->
<!-- UTSCOMJSON.match-media.component_type -->
<!-- UTSCOMJSON.match-media.children -->
<!-- UTSCOMJSON.match-media.example -->
<!-- UTSCOMJSON.match-media.reference -->
## movable-area
<!-- UTSCOMJSON.movable-area.description -->
<!-- UTSCOMJSON.movable-area.compatibility -->
<!-- UTSCOMJSON.movable-area.attribute -->
<!-- UTSCOMJSON.movable-area.event -->
<!-- UTSCOMJSON.movable-area.component_type -->
<!-- UTSCOMJSON.movable-area.children -->
<!-- UTSCOMJSON.movable-area.example -->
<!-- UTSCOMJSON.movable-area.reference -->
## movable-view
<!-- UTSCOMJSON.movable-view.description -->
<!-- UTSCOMJSON.movable-view.compatibility -->
<!-- UTSCOMJSON.movable-view.attribute -->
<!-- UTSCOMJSON.movable-view.event -->
<!-- UTSCOMJSON.movable-view.component_type -->
<!-- UTSCOMJSON.movable-view.children -->
<!-- UTSCOMJSON.movable-view.example -->
<!-- UTSCOMJSON.movable-view.reference -->
## navigation-bar
<!-- UTSCOMJSON.navigation-bar.description -->
<!-- UTSCOMJSON.navigation-bar.compatibility -->
<!-- UTSCOMJSON.navigation-bar.attribute -->
<!-- UTSCOMJSON.navigation-bar.event -->
<!-- UTSCOMJSON.navigation-bar.component_type -->
<!-- UTSCOMJSON.navigation-bar.children -->
<!-- UTSCOMJSON.navigation-bar.example -->
<!-- UTSCOMJSON.navigation-bar.reference -->
文档已迁移,请前往[nested-scroll](./nested-scroll.md)查看最新文档
## nested-scroll-body
<!-- UTSCOMJSON.nested-scroll-body.description -->
<!-- UTSCOMJSON.nested-scroll-body.compatibility -->
<!-- UTSCOMJSON.nested-scroll-body.attribute -->
<!-- UTSCOMJSON.nested-scroll-body.event -->
<!-- UTSCOMJSON.nested-scroll-body.component_type-->
### 使用场景
scroll-view 嵌套场景中。内层 scroll-view 滚动时无法与外层 scroll-view 滚动衔接,无法实现嵌套滚动连贯效果。因此提供`nested-scroll-body`节点,存放内层 scroll-view 节点。`nested-scroll-body`会与外层`nested-scroll-header`衔接滚动逻辑实现连贯滚动。开发者只需将内层滚动节点放置`nested-scroll-body`节点内即可。具体用法请参考[scroll-view嵌套模式](https://doc.dcloud.net.cn/uni-app-x/component/scroll-view.html#nested-scroll-view)
**注意**
+ `nested-scroll-body` 组件不支持css, 排版需求要交给子节点实现
+ `nested-scroll-body` 组件不支持复数子节点,渲染时会取其第一个子节点来渲染
+ `nested-scroll-body` 组件只能渲染在 `nested-scroll-header`组件下面
+ 外层 scroll-view 的子节点中只能有一个 `nested-scroll-body`
<!-- UTSCOMJSON.nested-scroll-body.children -->
<!-- UTSCOMJSON.nested-scroll-body.example -->
<!-- UTSCOMJSON.nested-scroll-body.reference -->
文档已迁移,请前往[nested-scroll](./nested-scroll.md)查看最新文档
## nested-scroll-header
<!-- UTSCOMJSON.nested-scroll-header.description -->
<!-- UTSCOMJSON.nested-scroll-header.compatibility -->
<!-- UTSCOMJSON.nested-scroll-header.attribute -->
<!-- UTSCOMJSON.nested-scroll-header.event -->
<!-- UTSCOMJSON.nested-scroll-header.component_type-->
### 使用场景
scroll-view 嵌套场景中。外层 scroll-view 滚动时无法与内层 scroll-view 滚动衔接连贯滚动,因此提供`nested-scroll-header`节点,存放除内层 scroll-view 以外的内容节点。`nested-scroll-body`内部 scroll-view 滚动时会检测`nested-scroll-header`节点滚动位置,约束内层 scroll-view 滚动逻辑,实现嵌套模式下衔接连贯滚动。开发者只需将外层要显示内容节点放置`nested-scroll-header`节点内即可。具体用法请参考[scroll-view嵌套模式](https://doc.dcloud.net.cn/uni-app-x/component/scroll-view.html#nested-scroll-view)
**注意**
+ `nested-scroll-header` 组件不支持css, 排版需求要交给子节点实现
+ `nested-scroll-header` 组件不支持复数子节点,渲染时会取其第一个子节点来渲染
+ `nested-scroll-header` 组件只能渲染在 `nested-scroll-body`组件上面
<!-- UTSCOMJSON.nested-scroll-header.children -->
<!-- UTSCOMJSON.nested-scroll-header.example -->
<!-- UTSCOMJSON.nested-scroll-header.reference -->
## nested-scroll-header
文档已迁移至:
<!-- UTSCOMJSON.nested-scroll-header.description -->
<!-- UTSCOMJSON.nested-scroll-header.compatibility -->
<!-- UTSCOMJSON.nested-scroll-header.attribute -->
<!-- UTSCOMJSON.nested-scroll-header.event -->
<!-- UTSCOMJSON.nested-scroll-header.component_type-->
### 使用场景
scroll-view 嵌套场景中。外层 scroll-view 滚动时无法与内层 scroll-view 滚动衔接连贯滚动,因此提供`nested-scroll-header`节点,存放除内层 scroll-view 以外的内容节点。`nested-scroll-body`内部 scroll-view 滚动时会检测`nested-scroll-header`节点滚动位置,约束内层 scroll-view 滚动逻辑,实现嵌套模式下衔接连贯滚动。开发者只需将外层要显示内容节点放置`nested-scroll-header`节点内即可。具体用法请参考[scroll-view嵌套模式](https://doc.dcloud.net.cn/uni-app-x/component/scroll-view.html#nested-scroll-view)
**注意**
+ `nested-scroll-header` 组件不支持css, 排版需求要交给子节点实现
+ `nested-scroll-header` 组件不支持复数子节点,渲染时会取其第一个子节点来渲染
+ `nested-scroll-header` 组件只能渲染在 `nested-scroll-body`组件上面
<!-- UTSCOMJSON.nested-scroll-header.children -->
<!-- UTSCOMJSON.nested-scroll-header.example -->
<!-- UTSCOMJSON.nested-scroll-header.reference -->
## nested-scroll-body
<!-- UTSCOMJSON.nested-scroll-body.description -->
<!-- UTSCOMJSON.nested-scroll-body.compatibility -->
<!-- UTSCOMJSON.nested-scroll-body.attribute -->
<!-- UTSCOMJSON.nested-scroll-body.event -->
<!-- UTSCOMJSON.nested-scroll-body.component_type-->
### 使用场景
scroll-view 嵌套场景中。内层 scroll-view 滚动时无法与外层 scroll-view 滚动衔接,无法实现嵌套滚动连贯效果。因此提供`nested-scroll-body`节点,存放内层 scroll-view 节点。`nested-scroll-body`会与外层`nested-scroll-header`衔接滚动逻辑实现连贯滚动。开发者只需将内层滚动节点放置`nested-scroll-body`节点内即可。具体用法请参考[scroll-view嵌套模式](https://doc.dcloud.net.cn/uni-app-x/component/scroll-view.html#nested-scroll-view)
**注意**
+ `nested-scroll-body` 组件不支持css, 排版需求要交给子节点实现
+ `nested-scroll-body` 组件不支持复数子节点,渲染时会取其第一个子节点来渲染
+ `nested-scroll-body` 组件只能渲染在 `nested-scroll-header`组件下面
+ 外层 scroll-view 的子节点中只能有一个 `nested-scroll-body`
<!-- UTSCOMJSON.nested-scroll-body.children -->
<!-- UTSCOMJSON.nested-scroll-body.example -->
<!-- UTSCOMJSON.nested-scroll-body.reference -->
- [nested-scroll-header](nested-scroll-header.md)
- [nested-scroll-body](nested-scroll-body.md)
## page-meta
<!-- UTSCOMJSON.page-meta.description -->
<!-- UTSCOMJSON.page-meta.compatibility -->
<!-- UTSCOMJSON.page-meta.attribute -->
<!-- UTSCOMJSON.page-meta.event -->
<!-- UTSCOMJSON.page-meta.component_type -->
<!-- UTSCOMJSON.page-meta.children -->
<!-- UTSCOMJSON.page-meta.example -->
<!-- UTSCOMJSON.page-meta.reference -->
## picker-view-column
<!-- UTSCOMJSON.picker-view-column.description -->
<!-- UTSCOMJSON.picker-view-column.compatibility -->
<!-- UTSCOMJSON.picker-view-column.attribute -->
<!-- UTSCOMJSON.picker-view-column.event -->
<!-- UTSCOMJSON.picker-view-column.component_type-->
<!-- UTSCOMJSON.picker-view-column.children -->
<!-- UTSCOMJSON.picker-view-column.example -->
<!-- UTSCOMJSON.picker-view-column.reference -->
......@@ -16,25 +16,6 @@
<!-- UTSCOMJSON.picker-view.reference -->
## picker-view-column
<!-- UTSCOMJSON.picker-view-column.description -->
<!-- UTSCOMJSON.picker-view-column.compatibility -->
<!-- UTSCOMJSON.picker-view-column.attribute -->
<!-- UTSCOMJSON.picker-view-column.event -->
<!-- UTSCOMJSON.picker-view-column.component_type-->
<!-- UTSCOMJSON.picker-view-column.children -->
<!-- UTSCOMJSON.picker-view-column.example -->
<!-- UTSCOMJSON.picker-view-column.reference -->
## tips
- picker里如放置较长内容,应该使用list-view而不是scroll-view。
- uni ui的[uni-data-picker](https://ext.dcloud.net.cn/plugin?id=3796),是封装好的弹出式、分列加载的、DataCom规范的多列选择组件,适用于地址选择等场景。
## picker
<!-- UTSCOMJSON.picker.description -->
<!-- UTSCOMJSON.picker.compatibility -->
<!-- UTSCOMJSON.picker.attribute -->
<!-- UTSCOMJSON.picker.event -->
<!-- UTSCOMJSON.picker.component_type -->
<!-- UTSCOMJSON.picker.children -->
<!-- UTSCOMJSON.picker.example -->
<!-- UTSCOMJSON.picker.reference -->
......@@ -17,22 +17,3 @@
<!-- UTSCOMJSON.radio-group.example -->
<!-- UTSCOMJSON.radio-group.reference -->
## radio
<!-- UTSCOMJSON.radio.description -->
<!-- UTSCOMJSON.radio.compatibility -->
<!-- UTSCOMJSON.radio.attribute -->
<!-- UTSCOMJSON.radio.event -->
<!-- UTSCOMJSON.radio.component_type-->
<!-- UTSCOMJSON.radio.children -->
<!-- UTSCOMJSON.radio.example -->
<!-- UTSCOMJSON.radio.reference -->
## radio
<!-- UTSCOMJSON.radio.description -->
<!-- UTSCOMJSON.radio.compatibility -->
<!-- UTSCOMJSON.radio.attribute -->
<!-- UTSCOMJSON.radio.event -->
<!-- UTSCOMJSON.radio.component_type -->
<!-- UTSCOMJSON.radio.children -->
<!-- UTSCOMJSON.radio.example -->
<!-- UTSCOMJSON.radio.reference -->
## sticky-header
<!-- UTSCOMJSON.sticky-header.description -->
<!-- UTSCOMJSON.sticky-header.compatibility -->
<!-- UTSCOMJSON.sticky-header.attribute -->
<!-- UTSCOMJSON.sticky-header.event -->
<!-- UTSCOMJSON.sticky-header.component_type-->
### sticky-header使用场景
1. 父元素滚动过程中,某个元素有固定到父元素顶部的需求
需求其实就是元素吸顶。可将需要吸顶元素放入sticky-header组件中,sticky-header组件作为父元素的子元素,放到吸顶元素原来的位置即可。
**示例:**
```html
<list-view id="list-view" style="flex: 1; background-color: #f5f5f5;">
<sticky-header>
<!-- 固定到父元素顶部的元素 -->
<text style="padding: 20px; background-color: #f5f5f5;">向上滑动页面,体验sticky-header吸顶效果。</text>
</sticky-header>
<list-item v-for="index in 20" :key="index" style="padding: 15px; margin: 5px 0;background-color: #fff;border-radius: 5px;">
<text class="text">itme-content-{{index}}</text>
</list-item>
</list-view>
```
**注意**
+ sticky-header组件不支持css。仅支持padding属性控制子元素位置。其他排版需求要交给子元素实现
+ 同时存在多sticky-header组件请使用sticky-section组件充当父容器控制吸顶业务
<!-- UTSCOMJSON.sticky-header.children -->
<!-- UTSCOMJSON.sticky-header.example -->
<!-- UTSCOMJSON.sticky-header.reference -->
## sticky-section
<!-- UTSCOMJSON.sticky-section.description -->
<!-- UTSCOMJSON.sticky-section.compatibility -->
<!-- UTSCOMJSON.sticky-section.attribute -->
<!-- UTSCOMJSON.sticky-section.event -->
<!-- UTSCOMJSON.sticky-section.component_type-->
### sticky-section使用场景
1. 父元素滚动过程中,多个元素有固定到父元素顶部的需求。
父元素中多个元素吸顶需要使用sticky-section组件。sticky-section组件作为sticky-header组件的父容器。sticky-section组件会控制子元素的滚动吸顶业务。sticky-section组件之间可通过push-pinned-header属性控制吸顶重叠时是否上推。
**示例:**
```html
<list-view id="list-view" style="flex: 1; background-color: #f5f5f5;">
<sticky-section v-for="sectionId in 3" :id="sectionId" push-pinned-header=false>
<sticky-header>
<text style="padding: 20px; background-color: #f5f5f5;">sticky-header吸顶--{{sectionId}}</text>
</sticky-header>
<list-item v-for="index in 20" :key="index" style="padding: 15px; margin: 5px 0;background-color: #fff;border-radius: 5px;">
<text class="text">itme-content-{{index}}</text>
</list-item>
</sticky-section>
</list-view>
```
**注意**
+ sticky-section组件支持存放多个sticky-header子组件,多个sticky-header滚动吸顶时,后一个sticky-header会停靠在前一个sticky-header的末尾处, 仅限于同一个sticky-section父容器。多个sticky-section吸顶停靠通过push-pinned-header控制。
+ sticky-section组件是虚拟组件不会真实渲染。仅支持padding属性控制子元素位置。其他排版需求要交给子元素实现
+ Android平台sticky-section组件作为list-view的子元素时需要注意,sticky-section子元素仅支持sticky-header、list-item,其他元素无法正常显示
<!-- UTSCOMJSON.sticky-section.children -->
<!-- UTSCOMJSON.sticky-section.example -->
<!-- UTSCOMJSON.sticky-section.reference -->
## sticky-header
文档已迁移至:
<!-- UTSCOMJSON.sticky-header.description -->
<!-- UTSCOMJSON.sticky-header.compatibility -->
<!-- UTSCOMJSON.sticky-header.attribute -->
<!-- UTSCOMJSON.sticky-header.event -->
<!-- UTSCOMJSON.sticky-header.component_type-->
### sticky-header使用场景
1. 父元素滚动过程中,某个元素有固定到父元素顶部的需求
需求其实就是元素吸顶。可将需要吸顶元素放入sticky-header组件中,sticky-header组件作为父元素的子元素,放到吸顶元素原来的位置即可。
**示例:**
```html
<list-view id="list-view" style="flex: 1; background-color: #f5f5f5;">
<sticky-header>
<!-- 固定到父元素顶部的元素 -->
<text style="padding: 20px; background-color: #f5f5f5;">向上滑动页面,体验sticky-header吸顶效果。</text>
</sticky-header>
<list-item v-for="index in 20" :key="index" style="padding: 15px; margin: 5px 0;background-color: #fff;border-radius: 5px;">
<text class="text">itme-content-{{index}}</text>
</list-item>
</list-view>
```
**注意**
+ sticky-header组件不支持css。仅支持padding属性控制子元素位置。其他排版需求要交给子元素实现
+ 同时存在多sticky-header组件请使用sticky-section组件充当父容器控制吸顶业务
<!-- UTSCOMJSON.sticky-header.children -->
<!-- UTSCOMJSON.sticky-header.example -->
<!-- UTSCOMJSON.sticky-header.reference -->
## sticky-section
<!-- UTSCOMJSON.sticky-section.description -->
<!-- UTSCOMJSON.sticky-section.compatibility -->
<!-- UTSCOMJSON.sticky-section.attribute -->
<!-- UTSCOMJSON.sticky-section.event -->
<!-- UTSCOMJSON.sticky-section.component_type-->
### sticky-section使用场景
1. 父元素滚动过程中,多个元素有固定到父元素顶部的需求。
父元素中多个元素吸顶需要使用sticky-section组件。sticky-section组件作为sticky-header组件的父容器。sticky-section组件会控制子元素的滚动吸顶业务。sticky-section组件之间可通过push-pinned-header属性控制吸顶重叠时是否上推。
**示例:**
```html
<list-view id="list-view" style="flex: 1; background-color: #f5f5f5;">
<sticky-section v-for="sectionId in 3" :id="sectionId" push-pinned-header=false>
<sticky-header>
<text style="padding: 20px; background-color: #f5f5f5;">sticky-header吸顶--{{sectionId}}</text>
</sticky-header>
<list-item v-for="index in 20" :key="index" style="padding: 15px; margin: 5px 0;background-color: #fff;border-radius: 5px;">
<text class="text">itme-content-{{index}}</text>
</list-item>
</sticky-section>
</list-view>
```
**注意**
+ sticky-section组件支持存放多个sticky-header子组件,多个sticky-header滚动吸顶时,后一个sticky-header会停靠在前一个sticky-header的末尾处, 仅限于同一个sticky-section父容器。多个sticky-section吸顶停靠通过push-pinned-header控制。
+ sticky-section组件是虚拟组件不会真实渲染。仅支持padding属性控制子元素位置。其他排版需求要交给子元素实现
+ Android平台sticky-section组件作为list-view的子元素时需要注意,sticky-section子元素仅支持sticky-header、list-item,其他元素无法正常显示
<!-- UTSCOMJSON.sticky-section.children -->
<!-- UTSCOMJSON.sticky-section.example -->
<!-- UTSCOMJSON.sticky-section.reference -->
- [sticky-header](sticky-header.md)
- [sticky-section](sticky-section.md)
## swiper-item
<!-- UTSCOMJSON.swiper-item.description -->
<!-- UTSCOMJSON.swiper-item.compatibility -->
<!-- UTSCOMJSON.swiper-item.attribute -->
<!-- UTSCOMJSON.swiper-item.event -->
<!-- UTSCOMJSON.swiper-item.component_type -->
<!-- UTSCOMJSON.swiper-item.children -->
<!-- UTSCOMJSON.swiper-item.example -->
<!-- UTSCOMJSON.swiper-item.reference -->
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册