第四章作业

本文详细描述了如何在微信小程序中使用JavaScript和CanvasAPI创建一个奥运五环动态效果,并展示了如何结合WXML和WXSS进行界面布局和交互设计,包括日期选择器的使用以及数据绑定和清除功能。
摘要由CSDN通过智能技术生成

 奥运

 js

Page({
 onLoad(options) {
  const ctx = wx.createCanvasContext('myCanvas');
  // 绘制蓝色环
  ctx.beginPath();
  ctx.arc(90,100,50, 0, 2 * Math.PI);
  ctx.setStrokeStyle('#0099CC');
  ctx.stroke();
  
  // 绘制黄色环
  ctx.beginPath();
  ctx.arc(170,100,50,  0, 2 * Math.PI);
  ctx.setStrokeStyle('#FFCC00');
  ctx.stroke();
  
  // 绘制黑色环
  ctx.beginPath();
  ctx.arc(250,100,50,  0, 2 * Math.PI);
  ctx.setStrokeStyle('#000000');
  ctx.stroke();
  
  // 绘制绿色环
  ctx.beginPath();
  ctx.arc(130,170,50,  0, 2 * Math.PI);
  ctx.setStrokeStyle('#339933');
  ctx.stroke();
  
  // 绘制红色环
  ctx.beginPath();
  ctx.arc(210,170,50,  0, 2 * Math.PI);
  ctx.setStrokeStyle('#CC0000');
  ctx.stroke();
  ctx.draw();
},
})

wxml

<canvas canvas-id="myCanvas" style="width: 300px; height: 300px;"></canvas>

书单

wxml

<image src="/pages/image/lp.jpg" class="f1"/>
<view class="s1">
  <image src="/pages/image/fw.jpg" mode=""/>
<view class="s2">
<view>格列佛游记</view>
<view>芭芭拉·明托(Barbara Minto)</view>
<view>介绍了一种能清晰地展现思路的高效方法,是训练思考、使表达呈现逻辑性的实用宝典。 金字塔原理能将零散的观点有序组织起来</view>
</view>
</view>
<view class="s1">
<image src="/pages/image/zl.jpg" mode=""/>
<view class="s2">
<view>海狼</view>
<view>吉姆·柯林斯 、 杰里·波拉斯</view>
<view>一书主要研究那些企业处于初创时期的状况,处于中型企业、大型公司时的情形,研究他们如何应对世界发生急剧变化</view>
</view>
</view>

wxss

.f1{
  width: 100%;
}
.s1{
  margin: auto;
  width: 335px;height: 160px;
  display: flex;
  border-bottom: 1px solid grey;
}
.s1 image{
height: 100px;width: 180px;
margin: 30px 0 0 0px;
}
.s2{
  margin: 30px 0 0 10px;
}
.s2 view:first-child{
  font-size: 20px;font-weight: bold;
}
.s2 view:nth-child(2){
  font-size: 15px; padding-top: 8px;
}
.s2 view:nth-child(3){
  padding-top: 8px;color: grey;
  font-size: 10px;
}

 拼车

js

<view class="first">联系方式(手机和微信至少填一项)</view>
 
<view >
<view class="s">
<view>称呼*</view> <input type="text" placeholder="请输入昵称"/>
</view>
<view class="s">
<view>手机号</view> <input type="text" placeholder="请输入手机号"/>
</view>
<view class="s">
<view>微信号</view> <input type="text" placeholder="请输入微信号"/>
</view>
</view>
 
<view class="first">拼车信息</view>
<view >
<view class="s">
<view>出发地点*</view> <input type="text" placeholder="限七个字"/>
</view>
<view class="s">
<view>目的地*</view> <input type="text" placeholder="限七个字"/>
</view>
<view class="s">
<view>空座数*</view> <input type="text" placeholder="请输入空座数"/>
</view>
</view>

 wxss

.first{
  width: 100%;height: 40px;background-color: #cccccc;line-height: 40px;padding-left: 15px;color: grey;border: 1px solid grey;
}
.s{
margin-left: 12px;   border-bottom: 1px solid grey;height: 50px;
}
.s view{
  float: left; width: 100px;line-height: 50px;font-weight: bold;
}
input{
 padding-top: 14px;
}

人生进程

js

Page({
 
  /**
   * 页面的初始数据
   */
  data: {
    startdate:2000,
    enddate:2050,
    date:'2004',
    n:"2004",
    y:"10",
    r:"24",
    e:"233"
  },
  changedate(e){
this.setData({date:e.detail.value});
console.log(e.detail.value);
 // 将字符串转换为Date对象
 let date = new Date(e.detail.value);
 // 创建一个Date对象
let sjc=new Date()//当前的时间
let newyear = sjc.getFullYear();  // 获取年份
 let newmonth = sjc.getMonth() + 1;  // 获取月份,需要+1因为月份是从0开始的
 // 获取年、月、日
 let year = date.getFullYear();  // 获取年份
 let month = date.getMonth() + 1;  // 获取月份,需要+1因为月份是从0开始的
 let day = date.getDate();  // 获取日
let yue=(newyear-year-1)*12+12-(month-newmonth)
console.log(yue);
 this.setData({n:year,y:month,r:day});
 this.setData({e:yue});
 
 // 打印结果
 console.log("年: " + year + ", 月: " + month + ", 日: " + day);
  },
  clean(){
this.setData({
  n:"",
  y:"",
  r:"",
  e:""
})
  },
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
 
  },
 
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
 
  },
 
  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {
 
  },
 
  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {
 
  },
 
  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {
 
  },
 
  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
 
  },
 
  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
 
  },
 
  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {
 
  }
})

wxml

<view class="f1">中国现阶段人均寿命900个月</view>
 
<view class="rq">{{n}}年{{y}}月{{r}}日至今{{e}}个月</view>
 
<view class="dd">
<picker mode="date" start="{{startdate}}" end="{{enddate}}" value="{{date}}" bindchange="changedate">
 <button style="width: 140px;"> 换一个日期</button>
</picker>
<button class="b" style="width: 120px;" bind:tap="clean">清除记录</button>
</view>
<image src="/images/tp6.png" mode=""/>
<view class="wz">能把在前面行走的机会抓住的人,十有八九都会成功。</view>

 wxss

.f1{
  text-align: center;
}
.rq{
  text-align: center;font-weight: bold;margin-top: 10px;
}
picker{
    float: left;
}
.dd{
margin: 25px 0 0 40px;
}
image{
  width: 200px;
  height: 380px; margin-left: 85px;
}
.wz{
  font-size: 16px;margin: 0 15px;font-weight: bold;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值