本地网站搭建如何访问网页,做统计表的网站,宁波网站建设价格合理,网站建设软件用乐云践新目录 一.小程序的布局
1.1. flex是什么
1.2. flex布局
1.3.总体布局
二.轮播图
2.1. 组件
2.2. 数据请求
2.3. 页面
三.首页
2.1. 视图
2.2.数据
2.3. 样式 好啦今天就到这里了#xff0c;希望能帮到你哦#xff01;#xff01;#xff01; 一.小程序的布局
…目录 一.小程序的布局
1.1. flex是什么
1.2. flex布局
1.3.总体布局
二.轮播图
2.1. 组件
2.2. 数据请求
2.3. 页面
三.首页
2.1. 视图
2.2.数据
2.3. 样式 好啦今天就到这里了希望能帮到你哦 一.小程序的布局
1.1. flex是什么 flex布局Flex是CSS中的一种布局模型全称为Flexible Box它用于设计网页布局。使用Flex布局你可以更轻松地控制和调整容器中子元素的位置和大小以实现响应式设计和更复杂的布局结构。 Flex程序设计Flex或Adobe Flex是一种开发技术用于构建富互联网应用程序RIAs。它允许开发者使用Adobe Flex框架和MXML一种XML语言来创建跨平台的富互联网应用程序。注意Adobe Flex于2011年停止维护后来开源并成为Apache Flex。 Flex工作制度在某些情况下flex可能指代一种灵活的工作安排即弹性工作。这种工作安排允许员工更灵活地管理他们的工作时间和地点通常通过远程工作或弹性工作时间来实现。 Flex语言Flex也可以指代一种编程语言特别是在数据交换和通信领域。这种语言通常用于创建XML文档并与其他系统进行数据交换。 在微信小程序中flex是一种布局方式用于实现弹性盒子布局。通过使用flex布局可以方便地实现页面元素的自适应和排列。flex布局主要通过设置父容器的flex属性来控制子元素的布局方式和占据空间的比例。具体来说可以通过设置父容器的flex-direction属性来指定子元素的排列方向水平或垂直通过设置父容器的justify-content属性来指定子元素在主轴上的对齐方式通过设置父容器的align-items属性来指定子元素在交叉轴上的对齐方式通过设置子元素的flex属性来指定子元素占据父容器剩余空间的比例等。通过灵活运用flex布局可以实现页面的自适应和灵活布局。 1.2. flex布局 在微信小程序中flex布局是一种弹性盒子布局用于实现页面元素的自适应和排列。通过使用flex布局可以方便地控制页面元素在水平或垂直方向上的排列方式和占据空间的比例。 在微信小程序中可以通过设置父容器的display: flex来启用flex布局。接下来可以使用一系列的flex属性来控制子元素的布局方式 - flex-direction指定子元素的排列方向可以是row水平方向column垂直方向row-reverse反向水平方向或column-reverse反向垂直方向。- justify-content指定子元素在主轴上的对齐方式可以是flex-start起始位置对齐flex-end结束位置对齐center居中对齐space-between两端对齐子元素之间平均分布space-around子元素周围平均分布等。- align-items指定子元素在交叉轴上的对齐方式可以是flex-start起始位置对齐flex-end结束位置对齐center居中对齐baseline基线对齐等。- flex-wrap指定子元素是否换行可以是nowrap不换行wrap换行或wrap-reverse反向换行。- align-content指定多行子元素在交叉轴上的对齐方式只有在有多行时才会生效可以是flex-start起始位置对齐flex-end结束位置对齐center居中对齐space-between两端对齐行之间平均分布space-around行周围平均分布等。 通过设置以上属性可以实现页面元素的自适应和灵活排列使页面在不同屏幕尺寸和设备上都能良好展示。 1.3.总体布局 根据我博客中进行创建一个微信小程序项目: 微信小程序入门级及安装https://blog.csdn.net/m0_74915426/article/details/133828417?spm1001.2014.3001.5502 之后在项目中增加三个页面 可以根据自己的需求进行更改命名 在项目的主体中找到 app.json 这个文件进行增加以上三个文件。 在该文件中找到 pages 在里面进行直接页面。 pages:[pages/index/index,pages/meeting/list/list,pages/vote/list/list,pages/ucenter/index/index,pages/logs/logs], 在进行一级页面的布局在项目的主体中找到 app.json 进行编写 tabBar: {list: [{pagePath: pages/index/index,text: 首页,iconPath: /static/tabBar/coding.png,selectedIconPath: /static/tabBar/coding-active.png},{pagePath: pages/meeting/list/list,iconPath: /static/tabBar/sdk.png,selectedIconPath: /static/tabBar/sdk-active.png,text: 会议},{pagePath: pages/vote/list/list,iconPath: /static/tabBar/template.png,selectedIconPath: /static/tabBar/template-active.png,text: 投票},{pagePath: pages/ucenter/index/index,iconPath: /static/tabBar/component.png,selectedIconPath: /static/tabBar/component-active.png,text: 设置}]}, 在项目的本地路径中创建一个静态资源文件夹 ( static ) 在静态资源文件夹 ( static )中创建一个放首页轮播图图片的文件夹 : tabBar 至于什么样的图片 : 可以自己在本地路径中进行增加 。 pagePath : 填写页面的地址 iconPath : 存放未选中的图片 selectedIconPath : 存放已选中的图片 text : 填写标题 二.轮播图
2.1. 组件 打开调试器在调试器中选中Mock点击加号进行增加一个API信息如图 : API的信息如图填写即可 : JSON的数据包在上图中右下角以下代码放入其中
{data: {images:[{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner1.png,text: 1},{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner2.png,text: 2},{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner3.png,text: 3},{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner4.png,text: 4},{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner5.png,text: 5},{img: https://cdn-we-retail.ym.tencent.com/tsr/home/v2/banner6.png,text: 6}
]},statusCode: 200,header: {content-type:applicaiton/json;charsetutf-8}
} 然后选择勾选进行使用如图: 2.2. 数据请求 在项目的本地路径中创建一个资源文件夹 ( config) 在去开发工具中在中共文件夹中创建一个 app.js 文件进行代码编写 : // 以下是业务服务器API地址// 本机开发API地址var WxApiRoot http://localhost:8080/demo/wx/;// 测试环境部署api地址// var WxApiRoot http://192.168.0.101:8070/demo/wx/;// 线上平台api地址//var WxApiRoot https://www.oa-mini.com/demo/wx/;module.exports {IndexUrl: WxApiRoot home/index, //首页数据接口SwiperImgs: WxApiRootswiperImgs, //轮播图MettingInfos: WxApiRootmeeting/list, //会议信息};
2.3. 页面 在 index.css 编写样式 page{ height: 100%; background-color: #efeff4; } 将 index.wxml 中的代码全部修改为一下代码: !--index.wxml--
viewswiper autoplaytrue indicator-dotstrue indicator-color#fff indicator-active-color#00fblock wx:for{{imgSrcs}} wx:keytextswiper-itemviewimage src{{item.img}} classswiper-item //view/swiper-item/block/swiper
/view 在 index.css 增加以下样式 .swiper-item {height: 300rpx;width: 100%;border-radius: 10rpx;
} 在 index.js 中将全部代码修改为以下代码 : // index.js
// 获取应用实例
const app getApp()
const api require(../../config/app)
Page({data: {},// 事件处理函数loadSwiperImgs(){let thatthis;wx.request({url: api.SwiperImgs,dataType: json,success(res) {console.log(res)that.setData({imgSrcs:res.data.images})}})},onLoad() {if (wx.getUserProfile) {this.setData({canIUseGetUserProfile: true})}this.loadSwiperImgs();},getUserProfile(e) {// 推荐使用wx.getUserProfile获取用户信息开发者每次通过该接口获取用户个人信息均需用户确认开发者妥善保管用户快速填写的头像昵称避免重复弹窗wx.getUserProfile({desc: 展示用户信息, // 声明获取用户个人信息后的用途后续会展示在弹窗中请谨慎填写success: (res) {console.log(res)this.setData({userInfo: res.userInfo,hasUserInfo: true})}})},getUserInfo(e) {// 不推荐使用getUserInfo获取用户信息预计自2021年4月13日起getUserInfo将不再弹出弹窗并直接返回匿名的用户个人信息console.log(e)this.setData({userInfo: e.detail.userInfo,hasUserInfo: true})}
}) 效果图在后面一起
三.首页 在静态资源文件夹 ( static ) 中创建一个放首页会议用户头像图片的文件夹 : persons 需要怎样的头像图片需要自行增加到其中。 注 : 需要在项目的本地路径下进行创建和增加 2.1. 视图 找到 index.wxml 将所有代码修改为以下代码 : !--index.wxml--
viewswiper autoplaytrue indicator-dotstrue indicator-color#fff indicator-active-color#00fblock wx:for{{imgSrcs}} wx:keytextswiper-itemviewimage src{{item.img}} classswiper-item //view/swiper-item/block/swiper
/view
view classmobi-titletext classmobi-icon/texttext会议信息/text
/view
block wx:for-items{{lists}} wx:for-itemitem wx:keyitem.idview classlist data-id{{item.id}}view classlist-imgimage classvideo-img modescaleToFill src{{item.image}}/image/viewview classlist-detailview classlist-titletext{{item.title}}/text/viewview classlist-tagview classstate{{item.state}}/viewview classjointext classlist-num{{item.num}} /text 人报名/view/viewview classlist-infotext{{item.location}}/text | text{{item.starttime}}/text/view/view/view
/block
view classsection bottom-linetext到底啦/text
/view
2.2.数据 找到 index.js 将所有代码修改为以下代码 : // index.js
// 获取应用实例
const app getApp()
const api require(../../config/app)
Page({//初始化数据data: {lists: [{id: 1,image: /static/persons/8.jpg,title: 对话产品总监 | 深圳·北京PM大会 【深度对话小米/京东/等产品总监】,num:304,state:进行中,starttime: 2022-03-13 00:00:00,location: 深圳市·南山区},{id: 1,image: /static/persons/1.png,title: AI WORLD 2016世界人工智能大会,num:380,state:已结束,starttime: 2022-03-15 00:00:00,location: 北京市·朝阳区},{id: 1,image: /static/persons/2.jpg,title: H100太空商业大会,num:500,state:进行中,starttime: 2022-03-13 00:00:00,location: 大连市},{id: 1,image: /static/persons/3.jpg,title: 报名年度盛事大咖云集2016凤凰国际论坛邀您“与世界对话”,num:150,state:已结束,starttime: 2022-03-13 00:00:00,location: 北京市·朝阳区},{id: 1,image: /static/persons/4.jpg,title: 新质生活 · 品质时代 2016消费升级创新大会,num:217,state:进行中,starttime: 2022-03-13 00:00:00,location: 北京市·朝阳区}]},statusCode: 200,header: {content-type:applicaiton/json;charsetutf-8},// 事件处理函数// 获取轮播图的方法loadSwiperImgs(){let thatthis;wx.request({url: api.SwiperImgs,dataType: json,success(res) {console.log(res)that.setData({imgSrcs:res.data.images})}})},
// 获取首页会议信息的方法loadMeetingInfos(){let thatthis;wx.request({url: api.MettingInfos,dataType: json,success(res) {console.log(res)that.setData({lists:res.data.lists})}})},onLoad() {if (wx.getUserProfile) {this.setData({canIUseGetUserProfile: true})}this.loadSwiperImgs();},getUserProfile(e) {// 推荐使用wx.getUserProfile获取用户信息开发者每次通过该接口获取用户个人信息均需用户确认开发者妥善保管用户快速填写的头像昵称避免重复弹窗wx.getUserProfile({desc: 展示用户信息, // 声明获取用户个人信息后的用途后续会展示在弹窗中请谨慎填写success: (res) {console.log(res)this.setData({userInfo: res.userInfo,hasUserInfo: true})}})},getUserInfo(e) {// 不推荐使用getUserInfo获取用户信息预计自2021年4月13日起getUserInfo将不再弹出弹窗并直接返回匿名的用户个人信息console.log(e)this.setData({userInfo: e.detail.userInfo,hasUserInfo: true})}
})
2.3. 样式 在 index.wxss 中编写样式进行美化页面以下是样式的所有代码 : /**index.wxss**/
.swiper-item {height: 300rpx;width: 100%;border-radius: 10rpx;
}
.mobi-title {font-size: 12pt;color: #777;line-height: 110%;font-weight: bold;width: 100%;padding: 15rpx;background-color: #f3f3f3;
}.mobi-icon {padding: 0rpx 3rpx;border-radius: 3rpx;background-color: #ff7777;position: relative;margin-right: 10rpx;
}/*list*/
.list {display: flex;flex-direction: row;width: 100%;padding: 0 20rpx 0 0;border-top: 1px solid #eeeeee;background-color: #fff;margin-bottom: 5rpx;/* border-radius: 20rpx;box-shadow: 0px 0px 10px 6px rgba(0,0,0,0.1); */
}.list-img {display: flex;margin: 10rpx 10rpx;width: 150rpx;height: 220rpx;justify-content: center;align-items: center;
}.list-img .video-img {width: 120rpx;height: 120rpx;}.list-detail {margin: 10rpx 10rpx;display: flex;flex-direction: column;width: 600rpx;height: 220rpx;
}.list-title text {font-size: 11pt;color: #333;font-weight: bold;
}.list-detail .list-tag {display: flex;height: 70rpx;
}.list-tag .state {font-size: 9pt;color: #81aaf7;width: 120rpx;border: 1px solid #93b9ff;border-radius: 2px;margin: 10rpx 0rpx;display: flex;justify-content: center;align-items: center;
}.list-tag .join {font-size: 11pt;color: #bbb;margin-left: 20rpx;display: flex;justify-content: center;align-items: center;
}.list-tag .list-num {font-size: 11pt;color: #ff6666;
}.list-info {font-size: 9pt;color: #bbb;margin-top: 20rpx;
}
.bottom-line{display: flex;height: 60rpx;justify-content: center;align-items: center;background-color: #f3f3f3;
}
.bottom-line text{font-size: 9pt;color: #666;
}
模拟器效果 好啦今天就到这里了希望能帮到你哦