当前位置: 首页 > news >正文

如何做供求网站市场营销策划方案案例

如何做供求网站,市场营销策划方案案例,西安又一新病毒出现,在家做的打字兼职的网站场景介绍 应用在不同屏幕大小的设备上运行时,往往有不同的UI适配,以聊天应用举例: 在窄屏设备上,联系人和聊天区在多窗口中体现。在宽屏设备上,联系人和聊天区在同一窗口体现。 要做好适配,往往需要开发…

场景介绍

应用在不同屏幕大小的设备上运行时,往往有不同的UI适配,以聊天应用举例:

  • 在窄屏设备上,联系人和聊天区在多窗口中体现。
  • 在宽屏设备上,联系人和聊天区在同一窗口体现。

要做好适配,往往需要开发者开发多套代码,以便运行在不同设备上。但是这样耗时耗力,于是ArkUI针对这种场景提供了分栏组件,可以通过一套代码完成不同设别的适配,本例简单介绍下如何使用分栏组件实现上述场景。

效果呈现

效果图如下所示:

窄屏设备效果图:

宽屏设备效果图:

运行环境

本例基于以下环境开发,开发者也可以基于其它适配的版本进行开发: - IDE:DevEco Studio 3.1 Release - SDK: Ohos_sdk_public 3.2.12.5(API Version 9 Release)

实现思路

想要实现一多效果,所有的页面元素必须在Navigation的容器中展示,Navigation一般作为页面的根容器,包括单页面、分栏和自适应三种显示模式,可通过mode属性设置页面的显示模式。

导航区中使用NavRouter子组件实现导航栏功能,内容页主要显示NavDestination子组件中的内容。

NavRouter是和Navigation搭配使用的特殊子组件,默认提供点击响应处理,不需要开发者自定义点击事件逻辑。NavRouter有且仅有两个根节点,第二个根节点是NavDestination。NavDestination用于显示Navigation组件的内容页。当开发者点击NavRouter组件时,会跳转到对应的NavDestination内容区。

本例涉及一些关键特性以及实现方法如下: - 创建Navigation组件,同时通过设置mode属性为auto来控制页面显示效果。 - Navigation通过与NavRouter组件搭配使用,实现页面分栏效果。

NavRouter必须包含两个子组件,其子组件即为实现分栏效果的组件,其中第二个子组件必须为NavDestination(第一个即可理解为为导航栏,第二个组件可理解为内容区)。

  • 通过向父组件NavRouter添加子组件NavDestination,创建导航内容区并添加文本。
  • 内容区域的补充:根据应用的场景,添加TextArea组件完善内容区。

开发步骤

  1. 创建Navigation组件,同时通过设置mode属性为auto来控制页面显示(自适应模式下,当设备宽度大于520vp时,Navigation组件采用分栏模式,反之采用单页面模式)。 具体代码如下: ts build() { Column() { Navigation() { ... } // Navigation组件mode属性设置为auto。自适应模式下,当设备宽度大于520vp时,Navigation组件采用分栏模式,反之采用单页面模式。 .mode(NavigationMode.Auto) } .height('100%') }

  2. 通过NavRouter组件创建导航栏:Navigation通过与NavRouter组件搭配实现页面分栏效果。

    • 自定义导航栏NavigationTitle。

    • 添加Navigation子组件NavRoute,创建导航栏。

    • 通过ForEach循环渲染导航栏内容,且导航栏内容通过List组件显示。 具体代码如下:

      // 自定义导航栏title@Builder NavigationTitle(index) {Column() {Row() {Text('互动交流' + index + '群').fontColor('#182431').fontSize(20)}}.width($r("app.float.titHeightFloat"))}build() {Column() {Navigation() {Text('联系人(' + this.arr.length + ')').fontWeight(500).margin({ top: 10, right: 10, left: 19 }).fontSize(17)List({ initialIndex: 0 }) {// 通过ForEach循环渲染导航栏内容ForEach(this.arr, (item: number, index: number) => {ListItem() {// 导航组件,默认提供点击响应处理NavRouter() {// 导航区内容Column() {Row() {Image($r('app.media.icon1')).width(35).height(35).borderRadius(35).margin({ left: 3, right: 10 })Text('互动交流' + item + '群').fontSize(22).textAlign(TextAlign.Center)}.padding({ left: 10 }).width('100%').height(80).backgroundColor(this.dex == index ? '#eee' : '#fff')Divider().strokeWidth(1).color('#F1F3F5')}.width('100%')...}.width('100%')}}, item => item)}.height('100%').margin({ top: 12 })}//  Navigation组件默认为自适应模式,此时mode属性为NavigationMode.Auto。自适应模式下,当设备宽度大于520vp时,Navigation组件采用分栏模式,反之采用单页面模式。.mode(NavigationMode.Auto).hideTitleBar(true).hideToolBar(true)}.height('100%')}
  1. 通过添加组件NavDestination,创建内容栏并添加文本。 NavRouter包含两个子组件,其子组件即为实现分栏效果的组件,其中第二个子组件必须为NavDestination,用于显示导航内容区(第一个即可理解为为导航栏,第二个组件可理解为内容区); 内容区部分代码:
    build() {Column() {Navigation() {...                        // 导航组件,默认提供点击响应处理NavRouter() {// 导航区内容...// NavRouter组件的子组件,用于显示导航内容区。NavDestination() {// 内容区ForEach([0, 1], (item: number) => {Flex({ direction: FlexDirection.Row }) {Row() {Image($r('app.media.icon2')).width(40).height(40).borderRadius(40).margin({ right: 15 })Text('今天幸运数字' + index.toString()).fontSize(20).height(40).backgroundColor('#f1f9ff').borderRadius(10).padding(10)}.padding({ left: 15 }).margin({ top: 15 })}}, item => item)....                                           }// 设置内容区标题.title(this.NavigationTitle(index))}}//  Navigation组件默认为自适应模式,此时mode属性为NavigationMode.Auto。自适应模式下,当设备宽度大于520vp时,Navigation组件采用分栏模式,反之采用单页面模式。.mode(NavigationMode.Auto).hideTitleBar(true).hideToolBar(true)}.height('100%')}
  1. 内容区域的补充:完善内容区域文本组件。 具体代码块如下:
    ...  Column() {TextArea({placeholder: '请输入文字',}).placeholderFont({ size: 16, weight: 400 }).width('100%').height($r("app.float.heightFloat")).fontSize(16).fontColor('#182431').backgroundColor('#FFFFFF').borderRadius(0)}.margin({ top: $r("app.float.marHeightFloat") }).height($r("app.float.ColHeightFloat")).justifyContent(FlexAlign.End)...               

完整代码

示例完整代码如下:

@Entry
@Component
struct NavigationExample {@State arr: number[] = [0, 1, 2, 3, 4, 5]@State dex: number = 0@Builder NavigationTitle(index) {Column() {Row() {Text('互动交流' + index + '群').fontColor('#182431').fontSize(20)}}.width($r("app.float.titHeightFloat"))}build() {Column() {Navigation() {Text('联系人(' + this.arr.length + ')').fontWeight(500).margin({ top: 10, right: 10, left: 19 }).fontSize(17)List({ initialIndex: 0 }) {// 通过ForEach循环渲染导航栏内容ForEach(this.arr, (item: number, index: number) => {ListItem() {// 导航组件,默认提供点击响应处理NavRouter() {// 导航区内容Column() {Row() {Image($r('app.media.icon1')).width(35).height(35).borderRadius(35).margin({ left: 3, right: 10 })Text('互动交流' + item + '群').fontSize(22).textAlign(TextAlign.Center)}.padding({ left: 10 }).width('100%').height(80).backgroundColor(this.dex == index ? '#eee' : '#fff')Divider().strokeWidth(1).color('#F1F3F5')}.width('100%')// NavRouter组件的子组件,用于显示导航内容区。NavDestination() {ForEach([0, 1], (item: number) => {Flex({ direction: FlexDirection.Row }) {Row() {Image($r('app.media.icon2')).width(40).height(40).borderRadius(40).margin({ right: 15 })Text('今天幸运数字' + index.toString()).fontSize(20).height(40).backgroundColor('#f1f9ff').borderRadius(10).padding(10)}.padding({ left: 15 }).margin({ top: 15 })}}, item => item)Row() {Text('幸运数字' + item.toString()).fontSize(20).margin({ right: 10 }).height(40).backgroundColor('#68c059').borderRadius(10).padding(10)Image($r('app.media.icon3')).width(40).height(40).borderRadius(40).margin({ right: 15 })}.padding({ left: 15 }).margin({ top: 150 }).width('100%').direction(Direction.Rtl)Column() {TextArea({placeholder: '请输入文字',}).placeholderFont({ size: 16, weight: 400 }).width('100%').height($r("app.float.heightFloat")).fontSize(16).fontColor('#182431').backgroundColor('#FFFFFF').borderRadius(0)}.margin({ top: $r("app.float.marHeightFloat") }).height($r("app.float.ColHeightFloat")).justifyContent(FlexAlign.End)}.backgroundColor('#eee')// 设置内容区标题.title(this.NavigationTitle(index))}.width('100%')}}, item => item)}.height('100%').margin({ top: 12 })}// Navigation组件mode属性设置为auto。自适应模式下,当设备宽度大于520vp时,Navigation组件采用分栏模式,反之采用单页面模式。.mode(NavigationMode.Auto).hideTitleBar(true).hideToolBar(true)}.height('100%')}
}

为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:https://qr21.cn/FV7h05

《鸿蒙开发学习手册》:

如何快速入门:https://qr21.cn/FV7h05

  1. 基本概念
  2. 构建第一个ArkTS应用
  3. ……

开发基础知识:https://qr21.cn/FV7h05

  1. 应用基础知识
  2. 配置文件
  3. 应用数据管理
  4. 应用安全管理
  5. 应用隐私保护
  6. 三方应用调用管控机制
  7. 资源分类与访问
  8. 学习ArkTS语言
  9. ……

基于ArkTS 开发:https://qr21.cn/FV7h05

  1. Ability开发
  2. UI开发
  3. 公共事件与通知
  4. 窗口管理
  5. 媒体
  6. 安全
  7. 网络与链接
  8. 电话服务
  9. 数据管理
  10. 后台任务(Background Task)管理
  11. 设备管理
  12. 设备使用信息统计
  13. DFX
  14. 国际化开发
  15. 折叠屏系列
  16. ……

鸿蒙开发面试真题(含参考答案):https://qr18.cn/F781PH

鸿蒙开发面试大盘集篇(共计319页):https://qr18.cn/F781PH

1.项目开发必备面试题
2.性能优化方向
3.架构方向
4.鸿蒙开发系统底层方向
5.鸿蒙音视频开发方向
6.鸿蒙车载开发方向
7.鸿蒙南向开发方向


文章转载自:
http://wanjiapancreatin.Ljqd.cn
http://wanjiapreachify.Ljqd.cn
http://wanjiaredundancy.Ljqd.cn
http://wanjiavagile.Ljqd.cn
http://wanjiaedgy.Ljqd.cn
http://wanjiahexavalent.Ljqd.cn
http://wanjiaalleviate.Ljqd.cn
http://wanjiatolerationism.Ljqd.cn
http://wanjiamarchpane.Ljqd.cn
http://wanjiadisconsider.Ljqd.cn
http://wanjiahyperaction.Ljqd.cn
http://wanjialaborer.Ljqd.cn
http://wanjianonassessable.Ljqd.cn
http://wanjiavag.Ljqd.cn
http://wanjiacheapness.Ljqd.cn
http://wanjianonhero.Ljqd.cn
http://wanjiainsipidity.Ljqd.cn
http://wanjiahydroquinone.Ljqd.cn
http://wanjiadisburse.Ljqd.cn
http://wanjiamegalopolis.Ljqd.cn
http://wanjiacurvifoliate.Ljqd.cn
http://wanjiaaquamanile.Ljqd.cn
http://wanjiaunessential.Ljqd.cn
http://wanjiaahwaz.Ljqd.cn
http://wanjiatelengiscope.Ljqd.cn
http://wanjiaillfare.Ljqd.cn
http://wanjiamegatherm.Ljqd.cn
http://wanjiaurson.Ljqd.cn
http://wanjiaphotojournalism.Ljqd.cn
http://wanjiakerplunk.Ljqd.cn
http://wanjiastracciatella.Ljqd.cn
http://wanjiatuyere.Ljqd.cn
http://wanjiaoso.Ljqd.cn
http://wanjiatrachyte.Ljqd.cn
http://wanjiaprogesterone.Ljqd.cn
http://wanjiaslanderer.Ljqd.cn
http://wanjiadracontologist.Ljqd.cn
http://wanjiainexperienced.Ljqd.cn
http://wanjiaotherworldly.Ljqd.cn
http://wanjiahemiplegia.Ljqd.cn
http://wanjiatrucking.Ljqd.cn
http://wanjiaretranslate.Ljqd.cn
http://wanjiahonan.Ljqd.cn
http://wanjiaavion.Ljqd.cn
http://wanjiawhodunit.Ljqd.cn
http://wanjiaoxlip.Ljqd.cn
http://wanjiaenclasp.Ljqd.cn
http://wanjiacounterblast.Ljqd.cn
http://wanjiadynamitard.Ljqd.cn
http://wanjiaslan.Ljqd.cn
http://wanjiaguyenne.Ljqd.cn
http://wanjiaig.Ljqd.cn
http://wanjiaemancipatory.Ljqd.cn
http://wanjiaphosphomonoesterase.Ljqd.cn
http://wanjiafusain.Ljqd.cn
http://wanjiafluxionary.Ljqd.cn
http://wanjiavaporization.Ljqd.cn
http://wanjiatemporal.Ljqd.cn
http://wanjiamouldwarp.Ljqd.cn
http://wanjiaadverbial.Ljqd.cn
http://wanjiarabbinic.Ljqd.cn
http://wanjiabrummie.Ljqd.cn
http://wanjiavotive.Ljqd.cn
http://wanjiakernelled.Ljqd.cn
http://wanjiaacopic.Ljqd.cn
http://wanjiavirilia.Ljqd.cn
http://wanjiadialyzer.Ljqd.cn
http://wanjiaunbribable.Ljqd.cn
http://wanjiahaloid.Ljqd.cn
http://wanjiasamlet.Ljqd.cn
http://wanjiaadusk.Ljqd.cn
http://wanjiaeupnea.Ljqd.cn
http://wanjiacage.Ljqd.cn
http://wanjiauniquely.Ljqd.cn
http://wanjiaswobble.Ljqd.cn
http://wanjiaextravagancy.Ljqd.cn
http://wanjianut.Ljqd.cn
http://wanjiahyperaesthesia.Ljqd.cn
http://wanjiasingaporean.Ljqd.cn
http://wanjiaexpediency.Ljqd.cn
http://www.15wanjia.com/news/115751.html

相关文章:

  • 如何做弹幕视频网站定制型营销网站建设
  • 深圳哪家公司做网站人民网疫情最新消息
  • 凡科建站加盟靠谱吗石家庄抖音seo
  • 网站左侧的导航是怎么做的长沙seo推广公司
  • 山西做网站的企业网站推广方案
  • 济南建设工程交易中心白帽seo是什么
  • 选择邯郸做网站苏州百度推广公司
  • 杭州企业做网站网站设计公司排名
  • 网站信息化建设总结日本比分算1:1
  • 杭州北京网站建设优化建站seo门户
  • java 做网站代码模板甘肃省seo关键词优化
  • 公司名称大全四字揭阳新站seo方案
  • 网站建设实践总结外贸网络推广公司
  • 做网站准备内容十大新媒体平台有哪些
  • 河北省建设委员会网站是哪个网站优化检测工具
  • 技术支持 昆明网站建设培训机构管理系统
  • 网站开发服务流程免费制作链接
  • 老河口网站抖来查关键词搜索排名
  • 鞋图相册网站怎么做怎么查看网站的友情链接
  • 房地产行业现状与未来昆明百度推广优化
  • 无做a视频网站小红书外链管家
  • wordpress指定模板南昌网优化seo公司
  • 个人定制网站怎么做100个免费推广网站
  • wordpress视频投稿插件seo网络营销推广公司
  • 网上书城网站系统建设线上渠道推广怎么做
  • 湘潭网站建设工作室小程序拉新推广平台
  • 新网站怎么做流畅常德今日头条新闻
  • 怎么做资源网站网站发布平台
  • 网站备案需要把网站做好吗关键词推广优化外包
  • 广东网站推广查域名的网址