项目文件:
链接:https://pan.baidu.com/s/1ayEpprM5nME1LYVOvKOw3w 提取码:hotu
Abstract:
Bike Sharing Website Development
Bikesharing.com is a new website and mobile companion app that is designed to promote increased use of cycling to and from work. Its main aim is to educate both employees and employers about the health and financial benefits of enrolling in the national cycle to work programme.
The website will be mostly informational – but will also contain maps of cycle ways and advice on cycles including reviews and maintenance.
As a junior web developer, you are to pitch for the Bikesharing.com website by developing a prototype website and supporting documentation. This includes the mark-up, project plan, visual design, content design, navigation design, and target audience/user scenarios (see individual worksheets for specific deliverables).
The prototype Website should work on HTML5 / CSS3 compliant browsers.
You are free to propose a suitable visual design that reflects the type of website and target audience requirements. There are no set colours or logos for Bikesharing.com – if you want to create these, you are free to do so!
There are 12 pages in this project. CSS and JavaScript are used for layout, and the framework of ‘layui’ is used for page beautification
In this page design, the interaction between the page and the user is completed. Users can easily get the information they want through page navigation, and the corresponding page is used to customize services for employers and employees. What’s more, a footer is used to display relevant copyright information as well. Styles and text are displayed clearly and concisely on each page. The whole project allows different types of users to achieve the corresponding requirements, and have good interaction.
Primary Audience:
The project is primarily aimed at employers who want employees in their group commute with Shared bikes.
The project is also primarily aimed at employees whose groups subscribe to our bike-sharing services
Secondary Audience:
The project is secondarily aimed at employees whose groups don’t subscribe to our bike-sharing services.
The project is secondarily aimed at Anyone who wants to use Shared bikes as a means of transportation.
Statement of Purpose
This page mainly accomplishes the following purposes:
Market Analysis
The main market of this Shared bike is for company employees and people who like cycling and exercise.
For the collective users of the company, we will provide customized services for them, and the company will pay the fees uniformly every year. All employees in the company can enjoy the Shared bikes at a lower price. They can find the available Shared bikes through the functions on the page and make route planning. This not only relieves the pressure of urban transportation to a certain extent, but also makes users healthier. In addition, Shared bikes are also environmentally friendly, greatly reducing carbon emissions. The main benefit will come from these companies’ collective users.
**Content Analysis: **
This navigation chart is mainly responsible for the pages jumping, providing guidance for users. Thus users are more convenient to find the content they want.
Primary content:
The navigation chart is designed to achieve the page jumping, including the main page, the company information page, employers information page employees information page, price calculating page and the message contact page.
Site-related content:
HOME Page(by clicking the‘HOME’button or the icon on the left side):
This is the page that users see when they enter the website for the first time. Users can view relevant information on the homepage and find the information they need under relevant guidance.
ABOUT Page:
On this page, users can view some information about the company, including the reasons for choosing Shared bikes, our strengths, the services we offer and our contact information.
EMPLOYERS Page:
On this page, employers can see if they want to subscribe to our services for their own companies, as well as the relevant administration advice and legislation and insurance information on this page.
EMPLOYEES Page:
On this page, employee users can use our interactive map to see the nearest available bike, whether their company has subscribed or not.
PRICE Page:
On this page, both employers and employees can use the interactive map provided by us to calculate the price or plan the path. We will provide the most suitable path for you to choose. We will also provide transparent pricing rules that you can use to plan your route or trip.
CONTACT US Page:
On this page, anyone can leave a comment or an idea. Whether you want to make a comment, or subscribe to our products, we welcome your letter. We will contact you within 24 hours after you leave your contact information.
Available content and resources:
On these pages, there are many resources available to the user. We provide information about the company to our users so that they know more about the company. Users can also use our page for route planning or distance and money calculations
In the homepage page we use the rotation pictures to attract the user. On other pages, users can share with the right button. Users can share this page to WeChat or QQ through this function. In addition, users can also use the page provided by us to find available Shared bikes nearby and implement functions such as route planning and route distance calculation. Users can also leave us a message and view some legal and insurance information. These resources are all detailed on our website.
①Rotating Pictures:
Rotating Pictures is a set of images that are scrolled in the right place at the right time so that the user can see the content of the image and be more interested in the content of the website.
Programming to realize:
Here we put the images into an unordered list.
<div id="container">
<div class="images">
<ul>
<li>
<img src="img/picture1.jpg" alt="Picture1" /> a>li>
<li>
<img src="img/picture2.jpg" alt="Picture2" /> a> li>
<li>
<img src="img/picture3.jpg" alt="Picture3" /> a>li>
<li>
<img src="img/picture4.jpg" alt="Picture4" /> a> li>
ul>
div>
div>
Then, animation is used to realize the Rotating Pictures
Since you want to animate in different browsers, three rules are used to animate separately, but since the code for each rule is exactly the same, only one is shown here.
#container .images>ul {
animation: wsBasic 16.8s infinite;
}
@keyframes wsBasic {
0% {
left: 0%
}
14.88% {
left: 0%
}
25% {
left: -100%
}
39.88% {
left: -100%
}
50% {
left: -200%
}
64.88% {
left: -200%
}
75% {
left: -300%
}
89.88% {
left: -300%
}
}
②The shares links which is combined with the right button on the page
Here, we directly use Baidu sharing API to share links to various social media. Users can share pages to different social platforms through this button, so as to expand the influence of the website.
Source code:
<!-- Baidu Button BEGIN -->
<script type="text/javascript" id="bdshare_js" data="type=slide&img=0&pos=right&uid=11824"></script>
<script type="text/javascript" id="bdshell_js"></script>
<script type="text/javascript">
var bds_config = { "bdTop": 155 };
document.getElementById("bdshell_js").src = "http://bdimg.share.baidu.com/static/js/shell_v2.js?cdnversion=" + new Date().getHours();
</script>
<!-- Baidu Button END -->
③Interactive buttons:
When your mouse passes the button, the color of the buttons changes.
Source code:
.tab>div {
width: 150px;
height: 40px;
background: #666;
border-radius: 20px;
margin: 0 20px;
color: #fff;
display: flex;
justify-content: center;
align-items: center;
}
.tab>div:hover {
cursor: pointer;
background: #f7941d;
}
The page jump here is implemented in JavaScript:
Source Code:
// 子导航
function tab(name) {
window.location.href = name + '.html';
}
④Communicate with customer service on QQ:
Here we use QQ promotion API to realizes chatting on QQ with customer service. You can chat with customer service on QQ directly.
Source code:
<p align="center">
<a target="_blank"
href="http://wpa.qq.com/msgrd?v=3&uin=2274006799&site=qq&menu=yes">
<img border="0" src="http://wpa.qq.com/pa?p=2:2274006799:53" alt="click here to send messages" title="click here to send messages" />
</a>
①Find bikes available nearby
In this function, we introduce the API of AutoNavi map to realize the positioning and searching of available bikes around users. After the project enters the back-end development, the positioning device on each bicycle can be used to refresh the positioning on the map in real time. This will greatly facilitate users to find their most convenient bikes.
Source code:
During the programming implementation, the map container is built and the corresponding and scaling levels are set. Then create the corresponding marker point.
<div id="container"></div>
<script>
//初始化地图插件
window.onload = function () {
var map = new AMap.Map("container", {
zoom: 15, //设置地图显示的缩放级别
center: [113.93318, 22.53701] //设置地图中心点坐标
});
// 创建一个 Marker 实例:(标记点)
var marker1 = new AMap.Marker({
position: new AMap.LngLat(113.98338, 22.53711),
title: "bicycle1 available"
});
var marker2 = new AMap.Marker({
position: new AMap.LngLat(113.91358, 22.53761),
title: "bicycle2 available"
});
var marker3 = new AMap.Marker({
position: new AMap.LngLat(113.93408, 22.59741),
title: "bicycle3 available"
});
var marker4 = new AMap.Marker({
position: new AMap.LngLat(113.98310, 22.54709),
title: "bicycle4 available"
});
var marker5 = new AMap.Marker({
position: new AMap.LngLat(113.93314, 22.53704),
title: "bicycle5 available"
});
// 将创建的点标记添加到已有的地图实例:
map.add(marker1);
map.add(marker2);
map.add(marker3);
map.add(marker4);
map.add(marker5);
}
</script>
②Price calculating and path planning
After the departure and destination points and corresponding prices are set, the prices are automatically calculated and the route is planned.
Source code:
To achieve this function, we first design the input box and set the initial value of the corresponding element. Then link into the AutoNavi map API, build the map container, and put the map and route plan into the container. Finally, the calculation is done through JavaScript and the container is set to the anchor point. When the button is clicked, the route is calculated and jumps to the anchor point, so that the user can see the price and route planning directly. In order to make the jump of the anchor not abrupt, smooth sliding is achieved through JavaScript, which makes the website more beautiful.
<div id="search">
<div id="searchText">Departure: </div><input type="text" name="" id="startNode" /><br /><br />
<div id="searchText">Destination: </div><input type="text" name="" id="endNode" /><br /><br />
<div id="searchText">Basic Distance: </div><input type="text" name="" id="send" value="2" /><br /><br />
<div id="searchText">Basic Price: </div><input type="text" name="" id="startPrice" value="0.1" /><br /><br />
<div id="searchText">Price Per Kilometre: </div><input type="text" name="" id="price" value="0.2" /><br /><br />
<a><button id="btn">Start to Calculate</button></a>
</div>
<div id="window-container">
<table id="window" align="center">
<tr>
<td>
<div id="container" align="center"></div>
</td>
<td>
<div id="panel"></div>
</td>
</tr>
</table>
</div>
<div id="result" align="center">
<br />
<b>Total Distance: </b><span id="road">xx km</span>
<b>Total Price: </b><span id="endPrice">xx ¥</span><br />
</div>
<div id="navigation">
<script>
var send = document.querySelector('#send')
var startPrice = document.querySelector('#startPrice')
var price = document.querySelector('#price')
var road = document.querySelector('#road')
var endPrice = document.querySelector('#endPrice')
//初始化地图
var map = new AMap.Map('container', {
center: [113.943487, 22.538249],
lang: "en"
});
new AMap.Autocomplete({
input: 'startNode'
});
new AMap.Autocomplete({
input: 'endNode'
});
btn.onclick = function () {
if (send.value && startPrice.value && price.value) {
//建立地图
new AMap.Riding({
map: map,
panel: 'panel'
}).search([
{ keyword: startNode.value, city: '深圳' },
{ keyword: endNode.value, city: '深圳' }
], function (status, data) {
var distance = data.routes[0].distance
console.log(data);
console.log(data.routes[0].distance)
//通过距离计算价格
if (distance > send.value * 1000) {
var newPrice = parseInt(startPrice.value) + Math.ceil(distance / 1000 - send.value) * price.value
endPrice.innerText = newPrice + ' ¥'
} else {
endPrice.innerText = startPrice.value + ' ¥'
}
road.innerText = (distance / 1000).toFixed(2) + ' km'
})
//锚点平滑滑动
let anchorElement = document.getElementById('window-container');
if (anchorElement) {
anchorElement.scrollIntoView({ behavior: 'smooth' });
}
} else {
alert('Please complete the information')
}
};
</script>
</div>
③Message board
In order to enable users to contact with us, in addition to the QQ for contact, also can give us a message to get in touch with us.
In this project, we created a form that allows users to leave messages by filling in the form. We also use JavaScript to check what is entered if the data is improperly formatted or forgotten. We will give you eye-catching hints.
It is worth noticing that in this project we also introduced a Layui framework for layout purposes.
Source code:
①Top:
Top navigation is in the vast majority of pages, playing the role of navigation which makes it convenient for users to choose information they want.
②Footer:
The bottom footer is also present on most pages and acts as a copyright notice.
③Index:
③About Us&employees&employmers:
In the four pages under this section, the CSS styling is basically the same, with only a few differences. Only one is shown here.
④Administration, Legislation and Insurance Information.
Due to the uncertainty of the content of relevant laws, ‘Sample document.’ is only used here instead of the actual content.
⑤Price Calculator:
Most of CSS styles of this page are similar to the rest of the page, so we don’t show them, just the different parts.
⑥Contact Us:
Most of CSS styles of this page are similar to the rest of the page, so we don’t show them, just the different parts.
This page is set with layui which makes the website more beautiful.
On this page, we use JavaScript to validate the input:
①For employers:
For employers, you are welcomed to visit this website.
This website provides you with a wealth of information about Shared bikes. You can have a deeper understanding of our services in this website. You can also subscribe to our bike-sharing service on this website for your employees.
The first thing you see is the home page, no matter which page you are in you can click the left art character or the navigation ‘HOME’ to jump to the homepage.
You can click “About us” to view some information about us. Here are your reasons to share, our advantages, our service and our contact.
You can also select the corresponding employers section, get more information to communicate with our customer service to subscribe, and view administration, legislation and insurance Information.
Whenever a problem occurs, you are welcomed to send us a message in ‘Contact Us’ page. Our staff will reply you in 24 hours.
②For employees and other visitors:
For employees, you are welcomed to visit this website.
This website provides you with a wealth of information about Shared bikes. You can have a deeper understanding of our services in this website. You can also enjoy the subscription of our bike-sharing service on this website in your group.
The first thing you see is the home page, no matter which page you are in you can click the left art character or the navigation ‘HOME’ to jump to the homepage.
You can click “About us” to view some information about us. Here are your reasons to share, our advantages, our service and our contact.
You can also select the corresponding employees section. Here, you can use our interactive map to find the nearest available Shared bikes quickly and easily.
No matter which page you are in, you can click the right orange button which links some social media platform to share this website to your friends.
We also provide you with a price calculator. Here you can calculate your costs and plan your path. We will provide you with convenient and safe cycling routes.
Whenever a problem occurs, you are welcomed to send us a message in ‘Contact Us’ page. Our staff will reply you in 24 hours.
Tasks | Solutions |
---|---|
Home Page | A home page is made with rotating pictures. |
Employers | A page is made especially for employers on which they can contact with our staff and get administration or insurance information. |
Employee | A page is made especially for employees on which they can find available bicycles easily. |
Cycle Reviews | Cycle Reviews and some related service can be offer when users contact with our staff. |
How to guides | A navigation is made to guide users to different information. |
Interactive Maps | A interactive map is made especially for users on which they can find available bicycles easily. |
Cost calculator | A cost calculator is made for price and path planning |
Social Media Integration | Users can click the right button to social media. |
Through the design of the bike-sharing website, I learned to make proper layout of the website and proper use of CSS and JavaScript. In addition, I also learned the process of doing a project, from the conception to the implementation of the code. Many difficulties were encountered, such as CSS typesetting errors, JavaScript did not run as desired results. At the beginning, what color to choose for the layout always bothered me. Later, when I saw the orange books on the table, I was inspired and chose orange as the overall style. A lot of difficulties have also occurred with JavaScript in projects. Because I’m not familiar with JavaScript, I often get errors or don’t get the results I want. Finally, after a little bit of testing, fortunately all have been solved. I also learned to read developer documentation for other platforms and use their APIs to achieve the functionality I wanted. This lays the foundation for the future study.
I benefited a lot from the study of front-end design in one semester and the design of this project in one month. The Front-end learning, makes me learn to use HTML to write beautiful pages, learn to use CSS to design the page style, learned to use JavaScript language programming to improve interaction. What’s more learned to reference the appropriate framework to improve the appearance of page style and interaction.
In addition, it also cultivated my character of never giving up. In the design of CSS styles, I will often come across styles that are not what I want them to be. This is where the changes need to be made. Analyzing the causes and making modifications becomes particularly important. Little by little, patient modification and debugging are essential to getting the style right. Every time I tried to correct the mistakes; I had a feeling that some of my knowledge was not solid.
In the future study, I will keep this course in mind, and never forget what this project brings me.