文章目录
- 1 简介
- 2 基础功能
- 3 美化
- 4 完整代码
1 简介
减肥一个多月了,一直想做一个记录自己运动的网页,以下是关于这次网页的记录、
简单结合了html和SD。
2 基础功能
第一个要实现的功能是将我想展示的数据显示出来。如果直接将这些数据写在html文件里,那么代码将,,,
那么对此我想到了几种方法
- 使用MySQL记录
- 使用sqlite记录
- 使用json文件记录
我仅仅是想制作一个简单记录自己运动的网页,不想搞的比较麻烦(好吧就是我懒),第三种方式对我来说完全够用
我暂时想记录的数据只有日期,步数,跑步或骑车的距离,json文件写成这样就可以
[ { "date": "07-21", "steps": 5678, "run": "2", "bike": "1" }, { "date": "07-20", "steps": 3456, "run": "2", "bike": "1" }, { "date": "07-18", "steps": 5678, "run": "2", "bike": "1" } ]
复制
然后是html文件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>运动记录</title> <style> .main_data_container { overflow-y: scroll; border: 1px solid #ccc; padding: 10px; } .main_data_item { text-align: center; margin-bottom: 10px; border-bottom: 1px dotted #ccc; padding-bottom: 5px; } </style> </head> <body> <h1>我的运动记录</h1> <div class="main_data_container"> <!-- 数据动态生成 --> <script> fetch('data.json') .then(response => response.json()) .then(data => { const logContainer = document.querySelector('.main_data_container'); data.forEach(item => { const logItem = document.createElement('div'); logItem.className = 'main_data_item'; logItem.innerHTML = ` <strong>日期:</strong> ${item.date}<br> <strong>步数:</strong> ${item.steps}<br> <strong>跑步:</strong> ${item.run} km<br> <strong>骑车:</strong> ${item.bike} km<br> `; logContainer.appendChild(logItem); }); }) .catch(error => console.error('Error loading the data:', error)); </script> </div> </body> </html>
复制
实现的功能非常简单,就是从json中读取数据,效果如下
,,,非常的简陋
3 美化
因此,我应该给它加一个合适的背景,没什么思路,浏览器不知道该怎么去搜,这个重任就理应落到了AI的头上,
千问生成的第一张图片给我的感觉很好,但我并不想要鞋子这个元素,或者是,它占的太大了,就和广告一样,原本想直接让千问生成到底,结果问了几次它傻了
接下来我想到了PS,根据千问的灵感去画一下就好了,等等,我好像不会PS。。
用PS做了一张与原来差不(hen)多的图,反手将它丢给SD
无脑抽了60张卡后挑了张有点感觉的
再把这个喂给SD重绘,放大,用PS涂抹掉瑕疵
能用,看下效果
有点单调,再添个进度条,每天步数高于5000就算100%
大功告成
4 完整代码
完整代码如下
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>运动记录</title> <style> .main_data_container { margin: 0 auto; width: 600px; border: 3px solid #ccc; padding: 10px; } .main_data_item { text-align: center; margin-bottom: 10px; border-bottom: 1px dotted #ccc; padding-bottom: 5px; font-size: 20px; } body { background-image:url('./img_src/A.png'); background-attachment: fixed; background-size: cover; background-position: center; } </style> <link rel="stylesheet" href="process.css"> </head> <body> <h1 style="color: white;text-align: center;">我的运动记录</h1> <div class="main_data_container"> <!-- 数据动态生成 --> <script> fetch('data.json') .then(response => response.json()) .then(data => { const logContainer = document.querySelector('.main_data_container'); data.forEach(item => { const logItem = document.createElement('div'); logItem.className = 'main_data_item'; logItem.innerHTML = ` <strong>日期:</strong> ${item.date}<br> <strong>步数:</strong> ${item.steps}<br> <strong>跑步:</strong> ${item.run} km<br> <strong>骑车:</strong> ${item.bike} km<br> <!-- 进度条--> <div style="border-radius: 7px;width: 200px; background-color: #ddd; margin: 0 auto;"> <div style=" --progress-width: ${Math.min(100, (item.steps / 5000) * 100)}%; border-radius: 7px; background-color: #4CAF50; text-align: right; padding-right: 5px; color: white; line-height: 20px; animation: loadProgress 1s ease-out forwards; width: 0%;"> ${Math.min(100, (item.steps / 5000) * 100).toFixed(2)}% </div> </div> `; logContainer.appendChild(logItem); }); }) .catch(error => console.error('Error loading the data:', error)); </script> </div> </body> </html>
复制
为了能够让进度条加载时动起来,还要有一个process.css
的文件,代码
@keyframes loadProgress { from { width: 0%; } to { width: var(--progress-width); } }
复制