鸿蒙5.0版开发:ArkTS组件通用属性-菜单控制
往期鸿蒙全套实战文章必看:[*] 鸿蒙开发焦点知识点,看这篇文章就够了
[*] 最新版!鸿蒙HarmonyOS Next应用开发实战学习门路
[*] 鸿蒙HarmonyOS NEXT开发技能最全学习门路指南
[*] 鸿蒙应用开发实战项目,看这一篇文章就够了(部分项目附源码)
菜单控制
为组件绑定弹出式菜单,弹出式菜单以垂直列表情势显示菜单项,可通过长按、点击或鼠标右键触发。
阐明:
[*] 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
[*] CustomBuilder里不支持再使用bindMenu、bindContextMenu弹出菜单。多级菜单可使用Menu组件。
[*] 弹出菜单的文本内容不支持长按选中。
[*] 当窗口大小发生变革时,菜单自动隐蔽。
[*] 动效曲线使用弹簧曲线,在动效退出时,由于弹簧曲线的回弹震荡,菜单消失后有较长的拖尾,使得其他变乱无法响应。
[*] 若组件是可拖动节点,绑定bindContextMenu未指定preview时,菜单弹出会浮起拖拽预览图且菜单选项和预览图不会发生避让。对此,开发者可根据使用场景设置preview或者将目标节点设置成不可拖动节点。
[*] 从API Version 12开始,菜单支持长按500ms弹出子菜单。
[*] 从API Version 12开始,菜单支持按压态跟随手指移动。
[*] 仅支持使用Menu组件且子组件包罗MenuItem或MenuItemGroup的场景。
[*] 仅支持MenuPreviewMode为NONE的菜单。
bindMenu
bindMenu(content: Array<MenuElement> | CustomBuilder, options?: MenuOptions)
给组件绑定菜单,点击后弹出菜单。弹出菜单项支持图标+文本排列和自定义两种功能。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明contentArray<MenuElement> | CustomBuilder是设置菜单项图标和文本的数组,或者自定义组件。optionsMenuOptions否设置弹出菜单的参数。 bindMenu11+
bindMenu(isShow: boolean, content: Array<MenuElement> | CustomBuilder, options?: MenuOptions)
给组件绑定菜单,点击后弹出菜单。弹出菜单项支持图标+文本排列和自定义两种功能。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明isShow11+boolean是支持开发者通过状态变量控制显隐,默认值为false,menu弹窗必须等待页面全部构建才气展示,因此不能在页面构建中设置为true,否则会导致显示位置及外形错误,当前不支持双向绑定。contentArray<MenuElement> | CustomBuilder是设置菜单项图标和文本的数组,或者自定义组件。optionsMenuOptions否设置弹出菜单的参数。 bindContextMenu8+
bindContextMenu(content: CustomBuilder, responseType: ResponseType, options?: ContextMenuOptions)
给组件绑定菜单,触发方式为长按或者右键点击,弹出菜单项需要自定义。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
参数:
参数名类型必填阐明contentCustomBuilder是自定义菜单内容构造器。responseTypeResponseType是菜单弹出条件,长按或者右键点击。不支持鼠标长按。optionsContextMenuOptions否设置弹出菜单的参数。 bindContextMenu12+
bindContextMenu(isShown: boolean, content: CustomBuilder, options?: ContextMenuOptions)
给组件绑定菜单,触发方式为控制绑定的isShown。
isShown为true,弹出菜单。isShown为false,隐蔽菜单。弹出菜单项需要自定义。
菜单弹出不跟随点击位置,只与placement设置有关。
体系能力: SystemCapability.ArkUI.ArkUI.Full
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
参数:
参数名类型必填阐明isShownboolean是支持开发者通过状态变量控制显隐,默认值为false。menu需要在页面全部构建完成后才气弹窗展示,假如在页面构建前或构建中设置为true,可能导致显示位置及外形错误、无法正常弹出显示等题目。当前不支持双向绑定,不支持长按触发拖拽。contentCustomBuilder是自定义菜单内容构造器。optionsContextMenuOptions否设置弹出菜单的参数。 MenuElement
名称类型必填描述valueResourceStr是菜单项文本。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。icon10+ResourceStr否菜单项图标。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。enabled11+boolean否菜单条目是否可进行交互。
默认值:true, 菜单条目可以进行交互。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。action() => void是点击菜单项的变乱回调。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。symbolIcon12+SymbolGlyphModifier否设置菜单项图标。通过Modifier设置菜单项图标,设置该项时,原icon图标不显示。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。 MenuOptions10+
继承自ContextMenuOptions。
名称类型必填描述titleResourceStr否菜单标题。
阐明:
仅在content设置为Array<MenuElement> 时生效。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。showInSubWindow11+boolean否是否在子窗口显示菜单。
默认值:2in1设备为true,其他设备为false。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。 ContextMenuOptions10+
名称类型必填描述offsetPosition否菜单弹出位置的偏移量,不会导致菜单显示超出屏幕范围。
默认值:{ x: 0, y: 0 }
阐明:
菜单类型为相对⽗组件地域弹出时,⾃动根据菜单位置属性 (placement)将地域的宽或⾼计⼊偏移量中。
当菜单相对父组件出现在上侧时(placement设置为Placement.TopLeft,Placement.Top,Placement.TopRight),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向上进行偏移。
当菜单相对父组件出现在下侧时(placement设置为Placement.BottomLeft,Placement.Bottom,Placement.BottomRight),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向下进行偏移。
当菜单相对父组件出现在左侧时(placement设置为Placement.LeftTop,Placement.Left,Placement.LeftBottom),x为正值,菜单相对组件向左进行偏移,y为正值,菜单相对组件向下进行偏移。
当菜单相对父组件出现在右侧时(placement设置为Placement.RightTop,Placement.Right,Placement.RightBottom),x为正值,菜单相对组件向右进行偏移,y为正值,菜单相对组件向下进行偏移。
假如菜单调整了显示位置(与placement初始值主方向不⼀致),则偏移值 (offset) 失效。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。placementPlacement否菜单组件优先显示的位置,当前位置显示不下时,会自动调整位置。
阐明:
placement值设置为undefined、null或没有设置此选项时,按未设置placement处理惩罚,当使用bindMenu,按默认值:Placement.BottomLeft设置,当使用bindContextMenu8+,菜单跟随点击位置弹出;当使用bindContextMenu12+,按默认值:Placement.BottomLeft设置。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。enableArrowboolean否是否显示箭头。假如菜单的大小和位置不足以放置箭头时,不会显示箭头。
默认值:false, 不显示箭头。
阐明:
enableArrow为true时,placement未设置或者值为非法值,默认在目标物上方显示,否则按照placement的位置优先显示。当前位置显示不下时,会自动调整位置,enableArrow为undefined时,不显示箭头。bindContextMenu从API version 10开始支持该属性;bindMenu从API version 12开始支持该属性。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。arrowOffsetLength否箭头在菜单处的偏移。偏移量必须合法且转换为具体数值时大于0才会生效,另外该值生效时不会导致箭头超出菜单四周的安全距离。
默认值:0
单位:vp
阐明:
箭头距菜单四周的安全距离为菜单圆角大小与箭头宽度的一半之和。
根据设置的placement来计算是在水平还是垂直方向上偏移。
箭头在菜单水平方向时,偏移量为箭头至最左侧箭头安全距离处的距离。箭头在菜单垂直方向时,偏移量为箭头至最上侧箭头安全距离处的距离。
根据设置的placement的不同,箭头展示的默认位置不同:
在菜单不发生避让的环境下,placement设置为Placement.Top、Placement.Bottom时,箭头显示在水平方向且默认居中;
placement设置为Placement.Left、Placement.Right时,箭头显示在垂直方向且默认居中;
placement设置为Placement.TopLeft、Placement.BottomLeft时,箭头默认显示在水平方向,且距离菜单左侧边缘距离为箭头安全距离;
placement设置为Placement.TopRight、Placement.BottomRight时,箭头默认显示在水平方向,且距离菜单右侧距离为箭头安全距离;
placement设置为Placement.LeftTop、Placement.RightTop时,箭头默认显示在垂直方向,且距离菜单上侧距离为箭头安全距离;
placement设置为Placement.LeftBottom、Placement.RightBottom时,箭头默认显示在垂直方向,且距离菜单下侧距离为箭头安全距离;
bindContextMenu从API version 10开始支持该属性;bindMenu从API version 12开始支持该属性。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。preview11+MenuPreviewMode| CustomBuilder否长按悬浮菜单或使用bindContextMenu12+显示菜单的预览内容样式,可以为目标组件的截图,也可以为用户自定义的内容。
默认值:MenuPreviewMode.NONE, 无预览内容。
阐明:
- 不支持responseType为ResponseType.RightClick时触发,假如responseType为ResponseType.RightClick,则不会显示预览内容。
- 当未设置preview参数或preview参数设置为MenuPreviewMode.NONE时,enableArrow参数生效。
- 当preview参数设置为MenuPreviewMode.IMAGE或CustomBuilder时,enableArrow为true时也不显示箭头。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。previewAnimationOptions11+ContextMenuAnimationOptions否控制长按预览显示动画开始倍率和竣事倍率(相对预览原图比例)。
默认值:{ scale: , transition: undefined, hoverScale: undefined }。
阐明:
倍率设置参数小于等于0时,不生效。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。onAppear() => void否菜单弹出时的变乱回调。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。onDisappear() => void否菜单消失时的变乱回调。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。aboutToAppear() => void否菜单显示动效前的变乱回调。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。aboutToDisappear() => void否菜单退出动效前的变乱回调。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。backgroundColor11+ResourceColor否弹窗背板颜色。
默认值:Color.Transparent。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。backgroundBlurStyle11+BlurStyle否弹窗背板含糊材质。
默认值:BlurStyle.COMPONENT_ULTRA_THICK。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。transition12+TransitionEffect否设置菜单显示和退出的过渡效果。
阐明:
菜单退出动效过程中,进行横竖屏切换,菜单会避让。二级菜单不继承自定义动效。弹出过程可以点击二级菜单,退出动效执行过程不允许点击二级菜单。
详细描述见TransitionEffect对象阐明。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。borderRadius12+Length | BorderRadiuses | LocalizedBorderRadiuses否设置菜单的边框圆角半径。
默认值:2in1设备上默认值8vp,其他设备上默认值20vp。
阐明:
支持百分比。
当水平方向两个圆角半径之和的最大值超出菜单宽度或垂直方向两个圆角半径之和的最大值超出菜单高度时,采用菜单默认圆角半径值。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。 MenuPreviewMode11+
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
体系能力: SystemCapability.ArkUI.ArkUI.Full
名称描述NONE不显示预览内容。IMAGE预览内容为触发长按悬浮菜单组件的截图。 ContextMenuAnimationOptions11+
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
名称类型必填描述scaleAnimationRange<number>否动画开始和竣事时相对预览原图缩放比例。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。transition12+TransitionEffect否设置菜单显示和退出的过渡效果。
阐明:
菜单退出动效过程中,进行横竖屏切换,菜单会避让。二级菜单不继承自定义动效。弹出过程可以点击二级菜单,退出动效执行过程不允许点击二级菜单。
详细描述见TransitionEffect对象阐明。hoverScale12+AnimationRange<number>否设置预览自定义长按场景下,浮起原组件截图的缩放动画开始和竣事时相对预览原图缩放比例,且有与预览图的切换的过渡动效。
阐明:
倍率设置参数小于等于0时,不生效。
bindContextMenu12+场景下,不生效。
设置transition接口时,不生效。
使用此接口且同时使用scale接口时,scale接口起始值不生效。
为保障最佳体验,终极预览图尺寸不发起小于原组件截图尺寸。当前预览动效宽高会受组件截图和自定义预览大小影响,请根据实际使用环境自行保障展示效果。 AnimationRange11+
表示动画开始和竣事时相对预览原图缩放比例。
体系能力:SystemCapability.ArkUI.ArkUI.Full
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
取值范围阐明from表示动画开始时相对预览原图缩放比例,to表示动画竣事时相对预览原图缩放比例。 示例
示例1
普通菜单
// xxx.ets
@Entry
@Component
struct MenuExample {
build() {
Column() {
Text('click for Menu')
.bindMenu([
{
value: 'Menu1',
action: () => {
console.info('handle Menu1 select')
}
},
{
value: 'Menu2',
action: () => {
console.info('handle Menu2 select')
}
},
])
}
.width('100%')
.margin({ top: 5 })
}
}
https://i-blog.csdnimg.cn/direct/e461c653e9d04ef39de01ef0cd315ace.png
示例2
自定义内容菜单
@Entry
@Component
struct MenuExample {
@State listData: number[] =
@Builder MenuBuilder() {
Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) {
ForEach(this.listData, (item:number, index) => {
Column() {
Row() {
Image($r("app.media.icon")).width(20).height(20).margin({ right: 5 })
Text(`Menu${index as number + 1}`).fontSize(20)
}
.width('100%')
.height(30)
.justifyContent(FlexAlign.Center)
.align(Alignment.Center)
.onClick(() => {
console.info(`Menu${index as number + 1} Clicked!`)
})
if (index != this.listData.length - 1) {
Divider().height(10).width('80%').color('#ccc')
}
}.padding(5).height(40)
})
}.width(100)
}
build() {
Column() {
Text('click for menu')
.fontSize(20)
.margin({ top: 20 })
.bindMenu(this.MenuBuilder)
}
.height('100%')
.width('100%')
.backgroundColor('#f0f0f0')
}
}
https://i-blog.csdnimg.cn/direct/cefac9ff39964b5b86727f67f46a4561.png
示例3
菜单(长按触发显示)
// xxx.ets
@Entry
@Component
struct ContextMenuExample {
@Builder MenuBuilder() {
Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) {
Text('Test menu item 1')
.fontSize(20)
.width(100)
.height(50)
.textAlign(TextAlign.Center)
Divider().height(10)
Text('Test menu item 2')
.fontSize(20)
.width(100)
.height(50)
.textAlign(TextAlign.Center)
}.width(100)
}
build() {
Column() {
Text('LongPress for menu')
}
.width('100%')
.margin({ top: 5 })
.bindContextMenu(this.MenuBuilder, ResponseType.LongPress)
}
}
https://i-blog.csdnimg.cn/direct/397cc14618904358ba28091807766204.png
示例4
指向性菜单(右键触发显示)
// xxx.ets
@Entry
@Component
struct DirectiveMenuExample {
@Builder MenuBuilder() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Text('Options')
Divider().strokeWidth(2).margin(5).color('#F0F0F0')
Text('Hide')
Divider().strokeWidth(2).margin(5).color('#F0F0F0')
Text('Exit')
}
.width(200)
}
build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
Column() {
Text("DirectiveMenuExample")
.fontSize(20)
.width('100%')
.height("25%")
.backgroundColor('#F0F0F0')
.textAlign(TextAlign.Center)
.bindContextMenu(this.MenuBuilder, ResponseType.RightClick, {
enableArrow: true,
placement: Placement.Bottom
})
}
}
.width('100%')
.height('100%')
}
}
https://i-blog.csdnimg.cn/direct/c740432154b44f3c9c3ede46db37cbb8.png
示例5
长按悬浮菜单(预览内容为截图情势)
// xxx.ets
@Entry
@Component
struct Index {
private iconStr: ResourceStr = $r("app.media.icon")
@Builder
MyMenu() {
Menu() {
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
}
}
build() {
Column({ space: 50 }) {
Column() {
Column() {
Text('preview-image')
.width(200)
.height(100)
.textAlign(TextAlign.Center)
.margin(100)
.fontSize(30)
.bindContextMenu(this.MyMenu, ResponseType.LongPress,
{ preview: MenuPreviewMode.IMAGE,
previewAnimationOptions: {scale: },
})
.backgroundColor("#ff3df2f5")
}
}.width('100%')
}
}
}
https://i-blog.csdnimg.cn/direct/4be38842d667405b805f2cac3b49cb74.png
示例6
长按悬浮菜单(自定义预览内容)
// xxx.ets
@Entry
@Component
struct Index {
private iconStr: ResourceStr = $r("app.media.icon")
@Builder
MyMenu() {
Menu() {
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
}
}
@Builder
MyPreview() {
Column() {
Image($r('app.media.icon'))
.width(200)
.height(200)
}
}
build() {
Column({ space: 50 }) {
Column() {
Column() {
Text('preview-builder')
.width(200)
.height(100)
.textAlign(TextAlign.Center)
.margin(100)
.fontSize(30)
.bindContextMenu(this.MyMenu, ResponseType.LongPress,
{
preview: this.MyPreview
})
}
}.width('100%')
}
}
}
https://i-blog.csdnimg.cn/direct/076c3a6984064b778a3d931030b43261.png
示例7
通过绑定isShown控制菜单(自定义预览内容)
// xxx.ets
@Entry
@Component
struct Index {
private iconStr: ResourceStr = $r("app.media.icon")
@State isShown: boolean = false
@Builder
MyMenu() {
Menu() {
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
}
}
@Builder
MyPreview() {
Column() {
Image($r('app.media.icon'))
.width(200)
.height(200)
}
}
build() {
Column({ space: 50 }) {
Column() {
Column() {
Text('preview-builder')
.width(200)
.height(100)
.textAlign(TextAlign.Center)
.margin(100)
.fontSize(30)
.bindContextMenu(this.isShown, this.MyMenu,
{
preview: this.MyPreview,
onDisappear: ()=>{
this.isShown = false;
}
})
Button('click')
.onClick(()=>{
this.isShown = true;
})
}
}.width('100%')
}
}
}
示例8
通过transition自定义菜单和预览的显示/退出动效属性
// xxx.ets
@Entry
@Component
struct MenuExample {
@Builder MenuBuilder() {
Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) {
Text('Test menu item 1')
.fontSize(12)
.width(200)
.height(30)
.textAlign(TextAlign.Center)
Divider().height(10)
Text('Test menu item 2')
.fontSize(12)
.width(100)
.height(30)
.textAlign(TextAlign.Center)
}.width(100)
}
@Builder
MyPreview() {
Column() {
Image($r('app.media.icon'))
.width(50)
.height(50)
}
}
@State isShow:boolean = false
private iconStr: ResourceStr = $r("app.media.icon")
@Builder
MyMenu() {
Menu() {
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
}
}
build() {
Column() {
Button('LongPress bindContextMenu')
.margin({ top: 15 })
.bindContextMenu(
this.MenuBuilder,
ResponseType.LongPress,{
transition: TransitionEffect.OPACITY.animation({ duration: 4000, curve: Curve.Ease }).combine(
TransitionEffect.rotate({ z: 1, angle: 180 })),
preview: this.MyPreview,
previewAnimationOptions: {
scale: ,
transition: TransitionEffect.OPACITY.animation({ duration: 4000, curve: Curve.Ease }).combine(
TransitionEffect.rotate({ z: 1, angle: 180 }))
}
})
}
.width('100%')
.margin({ top: 5 })
}
}
https://i-blog.csdnimg.cn/direct/596d4e7a2e2c440293eeb5904cdbbd84.png
示例9
普通菜单(使用symbol类型图标)
// xxx.ets
import { SymbolGlyphModifier } from '@kit.ArkUI';
@Entry
@Component
struct MenuExample {
@State symbolIconModifier1: SymbolGlyphModifier = new SymbolGlyphModifier($r('sys.symbol.ohos_photo')).fontSize('24vp');
@State symbolIconModifier2: SymbolGlyphModifier = new SymbolGlyphModifier($r('sys.symbol.ohos_photo')).fontSize('24vp');
build() {
Column() {
Text('click for Menu')
}
.width('100%')
.margin({ top: 5 })
.bindMenu([
{
value: 'Menu1',
symbolIcon:this.symbolIconModifier1,
action: () => {
console.info('handle Menu1 select')
}
},
{
value: 'Menu2',
symbolIcon:this.symbolIconModifier2,
action: () => {
console.info('handle Menu2 select')
}
},
])
}
}
https://i-blog.csdnimg.cn/direct/33d053b5601943a3882389e6db8efe89.png
示例10
通过hoverScale实现组件截图到自定义预览图的一镜到底过渡动效
// xxx.ets
@Entry
@Component
struct Index {
private iconStr: ResourceStr = $r("app.media.app_icon")
@Builder
MyMenu() {
Menu() {
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
MenuItem({ startIcon: this.iconStr, content: "菜单选项" })
}
}
@Builder
MyPreview() {
Column() {
Image($r('app.media.example'))
.width(200)
.height(200)
}
}
build() {
Column({ space: 50 }) {
Column() {
Column() {
Image($r('app.media.example'))
.width(100)
.height(100)
.margin(100)
.bindContextMenu(this.MyMenu, ResponseType.LongPress,
{
preview: this.MyPreview,
previewAnimationOptions: {
hoverScale:
}
})
}
}.width('100%')
}
}
}
https://i-blog.csdnimg.cn/direct/bf018a50db6745a7bc87b01f8f77a3b3.png
https://i-blog.csdnimg.cn/direct/703087920c1e470298018f36136f0494.png
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]