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

北京学生做兼职的网站wordpress增加分类目录

北京学生做兼职的网站,wordpress增加分类目录,泉州模板做网站,wordpress 主题猫前面介绍了自适应布局#xff0c;但是将窗口尺寸变化较大时#xff0c;仅仅依靠自适应布局可能出现图片异常放大或页面内容稀疏、留白过多等问题。此时就需要借助响应式布局能力调整页面结构。 响应式布局 响应式布局是指页面内的元素可以根据特定的特征#xff08;如窗口…前面介绍了自适应布局但是将窗口尺寸变化较大时仅仅依靠自适应布局可能出现图片异常放大或页面内容稀疏、留白过多等问题。此时就需要借助响应式布局能力调整页面结构。 响应式布局 响应式布局是指页面内的元素可以根据特定的特征如窗口宽度、屏幕方向等自动变化以适应外部容器变化的布局能力。响应式布局中最常使用的特征是窗口宽度可以将窗口宽度划分为不同的范围下文中称为断点。当窗口宽度从一个断点变化到另一个断点时改变页面布局如将页面内容从单列排布调整为双列排布甚至三列排布等以获得更好的显示效果。 当前系统提供了如下三种响应式布局能力后文中我将依次展开介绍。 响应式布局能力简介断点将窗口宽度划分为不同的范围即断点监听窗口尺寸变化当断点改变时同步调整页面布局。媒体查询媒体查询支持监听窗口宽度、横竖屏、深浅色、设备类型等多种媒体特征当媒体特征发生改变时同步调整页面布局。栅格布局栅格组件将其所在的区域划分为有规律的多列通过调整不同断点下的栅格组件的参数以及其子组件占据的列数等实现不同的布局效果。 1. 断点 1.1. 断点是什么 断点以应用窗口宽度为切入点将应用窗口在宽度维度上分成了几个不同的区间即不同的断点在不同的区间下开发者可根据需要实现不同的页面布局效果。 断点名称取值范围**vp**设备xs[0, 320手表等超小屏sm[320, 600)手机竖屏md[600, 840)手机横屏折叠屏lg[840, ∞)平板2in1 设备 1.2. 监听断点 判断应用当前处于何种断点进而可以调整应用的布局。常见的监听断点变化的方法如下所示 获取窗口对象并监听窗口尺寸变化了解 通过媒体查询监听应用窗口尺寸变化掌握 借助栅格组件能力监听不同断点的变化掌握 2. 媒体查询获取当前断点 系统工具——BreakpointSystem 系统工具——BreakPointType 2.1 进行工具类封装 直接给上完整代码 import mediaQuery from ohos.mediaquery ​ declare interface BreakPointTypeOptionT {xs?: Tsm?: Tmd?: Tlg?: Txl?: Txxl?: T } ​ interface Breakpoint {name: stringsize: numbermediaQueryListener?: mediaQuery.MediaQueryListener } ​ export const BreakpointKey: string currentBreakpoint ​ export class BreakPointTypeT {options: BreakPointTypeOptionT ​constructor(option: BreakPointTypeOptionT) {this.options option} ​getValue(currentBreakPoint: string) {if (currentBreakPoint xs) {return this.options.xs} else if (currentBreakPoint sm) {return this.options.sm} else if (currentBreakPoint md) {return this.options.md} else if (currentBreakPoint lg) {return this.options.lg} else if (currentBreakPoint xl) {return this.options.xl} else if (currentBreakPoint xxl) {return this.options.xxl} else {return undefined}} } ​ export class BreakpointSystem {private currentBreakpoint: string mdprivate breakpoints: Breakpoint[] [{ name: xs, size: 0 }, { name: sm, size: 320 },{ name: md, size: 600 }, { name: lg, size: 840 }] ​public register() {this.breakpoints.forEach((breakpoint: Breakpoint, index) {let condition: stringif (index this.breakpoints.length - 1) {condition ( breakpoint.size vpwidth )} else {condition ( breakpoint.size vpwidth this.breakpoints[index 1].size vp)}console.log(condition)breakpoint.mediaQueryListener mediaQuery.matchMediaSync(condition)breakpoint.mediaQueryListener.on(change, (mediaQueryResult) {if (mediaQueryResult.matches) {this.updateCurrentBreakpoint(breakpoint.name)}})})} ​public unregister() {this.breakpoints.forEach((breakpoint: Breakpoint) {if (breakpoint.mediaQueryListener) {breakpoint.mediaQueryListener.off(change)}})} ​private updateCurrentBreakpoint(breakpoint: string) {if (this.currentBreakpoint ! breakpoint) {this.currentBreakpoint breakpointAppStorage.Setstring(BreakpointKey, this.currentBreakpoint)console.log(on current breakpoint: this.currentBreakpoint)}} } export const breakpointSystem new BreakpointSystem() 2.2. 通过应用级存储为所有页面提供断点 目前查询的内容只在当前页面可以使用如果希望应用中任意位置都可以使用咱们可以使用AppStorage 进行共享。 核心步骤 事件中通过AppStorage.set(key,value)的方式保存当前断点值 需要使用的位置通过AppStorage来获取即可 // 添加回调函数 listenerXS.on(change, (res: mediaquery.MediaQueryResult) {console.log(changeRes:, JSON.stringify(res))if (res.matches true) {// this.currentBreakpoint xsAppStorage.set(currentBreakpoint, xs)} }) 使用断点值 // 组件中引入 AppStorage StorageProp(currentBreakpoint) currentBreakpoint: CurrentBreakpoint xs ​ // 在需要的位置使用 AppStorage 中保存的断点值 Text(this.currentBreakpoint) 2.3. 使用断点 核心用法 导入 BreakpointSystem 实例化BreakpointSystem aboutToAppear中注册监听事件 aboutToDisappear中移除监听事件 通过 AppStorage结合 获取断点值即可 // 1. 导入 import { BreakPointType, BreakpointSystem, BreakpointKey } from ../../common/breakpointsystem ​ ​ Entry Component struct Example { ​// 2. 实例化breakpointSystem: BreakpointSystem new BreakpointSystem()// 4. 通过 AppStorage 获取断点值StorageProp(BreakpointKey)currentBreakpoint: string sm ​// 3. 注册及移除监听事件aboutToAppear(): void {this.breakpointSystem.register()} ​aboutToDisappear(): void {this.breakpointSystem.unregister()} ​build() {// 略} } 2.4. 案例-电影列表 使用刚刚学习的媒体查询工具结合断点来完成一个响应式案例效果达到跨任意终端皆能实现响应式布局的效果。 完整代码 import { BreakPointType, BreakpointSystem, BreakpointKey } from ../../common/breakpointsystem ​ interface MovieItem {title: stringimg: ResourceStr } ​ Entry Component struct Demo09_demo {items: MovieItem[] [{ title: 电影标题1, img: $r(app.media.ic_video_grid_1) },{ title: 电影标题2, img: $r(app.media.ic_video_grid_2) },{ title: 电影标题3, img: $r(app.media.ic_video_grid_3) },{ title: 电影标题4, img: $r(app.media.ic_video_grid_4) },{ title: 电影标题5, img: $r(app.media.ic_video_grid_5) },{ title: 电影标题6, img: $r(app.media.ic_video_grid_6) },{ title: 电影标题7, img: $r(app.media.ic_video_grid_7) },{ title: 电影标题8, img: $r(app.media.ic_video_grid_8) },{ title: 电影标题9, img: $r(app.media.ic_video_grid_9) },{ title: 电影标题10, img: $r(app.media.ic_video_grid_10) },]breakpointSystem: BreakpointSystem new BreakpointSystem()StorageProp(BreakpointKey)currentBreakpoint: string sm ​aboutToAppear(): void {this.breakpointSystem.register()} ​aboutToDisappear(): void {this.breakpointSystem.unregister()} ​build() {Grid() {ForEach(this.items, (item: MovieItem) {GridItem() {Column({ space: 10 }) {Image(item.img).borderRadius(10)Text(item.title).width(100%).fontSize(20).fontWeight(600) ​}}})}.columnsTemplate(new BreakPointType({xs: 1fr 1fr,sm: 1fr 1fr ,md: 1fr 1fr 1fr ,lg: 1fr 1fr 1fr 1fr }).getValue(this.currentBreakpoint)).rowsGap(10).columnsGap(10).padding(10)} } 效果 3. 栅格布局 Grid 栅格组件的本质是将组件划分为有规律的多列通过调整【不同断点】下的【栅格组件的列数】及【子组件所占列数】实现不同布局 比如 参考栅格列数设置: 核心用法 优先级从上往下 GridRow的 columns 属性、GridCol 的 span 属性掌握 GridRow 的 gutter属性、GridCol 的 offset 属性掌握 GridRow breakpoints属性 和 的 onBreakpointChange 事件了解 Entry Component struct Demo11_login {build() {Stack() {// 辅助用的栅格顶层粉色区域GridRow({ gutter: 10, columns: { sm: 4, md: 8, lg: 12 } }) {ForEach(Array.from({ length: 12 }), () {GridCol().width(100%).height(100%).backgroundColor(#baffa2b4)})}.zIndex(2).height(100%) ​// 内容区域GridRow({// TODO 分别设置不同断点的 列数columns: {sm: 4,md: 8,lg: 12}}) {// 列GridCol({// TODO 分别设置不同断点的 所占列数span: {sm: 4,md: 6,lg: 8},// TODO 分别设置不同断点的 偏移offset: {md: 1,lg: 2} ​}) {Column() {// logo文字LogoCom() ​// 输入框 底部提示文本InputCom() ​// 登录注册账号按钮ButtonCom() ​}}}.width(100%).height(100%).backgroundColor(#ebf0f2)}} } ​ Component struct LogoCom {build() {Column({ space: 5 }) {Image($r(app.media.ic_logo)).width(80)Text(登录界面).fontSize(23).fontWeight(900)Text(登录账号以使用更多服务).fontColor(Color.Gray)}.margin({ top: 100 })} } ​ Component struct InputCom {build() {Column() {Column() {TextInput({ placeholder: 账号 }).backgroundColor(Color.Transparent)Divider().color(Color.Gray)TextInput({ placeholder: 密码 }).type(InputType.Password).backgroundColor(Color.Transparent) ​}.backgroundColor(Color.White).borderRadius(20).padding({ top: 10, bottom: 10 }) ​Row() {Text(短信验证码登录).fontColor(#006af7).fontSize(14)Text(忘记密码).fontColor(#006af7).fontSize(14)}.width(100%).justifyContent(FlexAlign.SpaceBetween).margin({ top: 10 }) ​}.padding(5).margin({ top: 80 }) ​} } ​ Component struct ButtonCom {build() {Column({ space: 10 }) {Button(登录).width(90%)Text(注册账号).fontColor(#006af7).fontSize(16)}.margin({ top: 60 })} } 下面我给栅格布局加了颜色方便展示效果
http://www.hkea.cn/news/14352185/

相关文章:

  • 廊坊市做网站川沙网站建设
  • 贵阳网站建设报价江西省赣州
  • 北京网站开发制作成都必去十大网红景点
  • 有做销售产品的网站有哪些内容可以在自己家做外卖的网站
  • 桓台网站建设网站开发维护报价单
  • 肥西做网站百度怎么推广自己的视频
  • 网页设计与网站建设的报告小程序登录入口电脑
  • 领诺科技网站建设hois.skxy.wordpress
  • 网站页面设计服务番禺人才网地址
  • 通州专业网站制作如何制作课程网站模板下载
  • 永州企业网站开发在线图像制作
  • 网站开发能从事那些职业淄博企业做网站
  • 广州做网站商城的公司便利的网站建设公司
  • 建站小程序快速上线行者seo无敌
  • 网站建设招标文件技术部分通道一通道二通道三免费
  • 稀奇古怪好玩有用的网站临沂做进销存网站
  • 长春火车站停车场24小时收费标准台州seo
  • 网站建立的流程一键生成静态网页
  • 如何自己做个网站投资5万的小型加工厂
  • 营销型网站建设式球磨机公司制作网站跟企业文化的关系
  • 重庆专业网站排名团队网站logo一般做多大
  • 济南做网站优化哪家好广州的百度推广公司
  • 4s店网站建设方案娄底住房和城乡建设部网站
  • 做旅游网站一年能挣多少移动互联网的概念
  • 跨境浏览网站教师做课题可以参考什么网站
  • 重庆建站模板厂家网页微信客户端下载
  • 做招标代理应关注的网站网站设计高度
  • 电子商务主要学什么专业课程seo外链专员工作要求
  • 我想做个网站怎么做网站推广策划思路与执行
  • 临沂设计网站的公司wordpress国内网站