下面我将提供一个简单的JavaScript网页设计案例,该案例将实现一个动态的待办事项列表(Todo List)。用户可以在页面上添加新的待办事项,标记它们为已完成,以及删除它们。这个案例将使用HTML来构建页面结构,CSS来美化页面,以及JavaScript来添加动态功能。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Todo List</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<h1>Todo List</h1>
<input type="text" placeholder="Add new todo...">
<button onclick="addTodo()">Add Todo</button>
<ul>
<!-- Todo items will be added here -->
</ul>
<script src="script.js"></script>
</body>
</html>
body {
font-family: Arial, sans-serif;
margin: 20px;
padding: 0;
}
#todoList {
list-style-type: none;
padding: 0;
}
#todoList li {
margin: 10px 0;
padding: 10px;
background-color: #f4f4f4;
border: 1px solid #ddd;
display: flex;
align-items: center;
justify-content: space-between;
}
#todoList li.completed {
text-decoration: line-through;
opacity: 0.5;
}
#todoInput {
padding: 10px;
margin-right: 10px;
width: calc(100% - 120px);
}
button {
padding: 10px 20px;
cursor: pointer;
}
function addTodo() {
const input = document.getElementById('todoInput');
const list = document.getElementById('todoList');
const itemText = input.value.trim();
if (itemText) {
const itemElement = document.createElement('li');
itemElement.textContent = itemText;
// Checkbox for marking todo as completed
const checkbox = document.createElement('input');
checkbox.type = 'checkbox';
checkbox.onclick = function() {
itemElement.classList.toggle('completed', this.checked);
};
// Button for deleting todo
const deleteButton = document.createElement('button');
deleteButton.textContent = 'Delete';
deleteButton.onclick = function() {
list.removeChild(itemElement);
};
// Append elements to the list item
itemElement.appendChild(checkbox);
itemElement.appendChild(document.createTextNode('\u00A0')); // Add space
itemElement.appendChild(deleteButton);
// Append list item to the list
list.appendChild(itemElement);
// Clear input field
input.value = '';
}
}
// Optionally, add event listener to input field for Enter key press
document.getElementById('todoInput').addEventListener('keypress', function(event) {
if (event.key === 'Enter') {
addTodo();
}
});
(1)HTML 部分定义了页面的基本结构,包括一个输入框用于输入待办事项,一个按钮用于添加待办事项,以及一个无序列表用于显示待办事项。
(2)CSS 部分美化了页面,包括待办事项列表的样式、输入框和按钮的样式。
(3)JavaScript 部分实现了动态功能:
addTodo
函数。addTodo
函数从输入框中获取文本,创建一个新的列表项,并为其添加复选框和删除按钮。keypress
事件,以便在按下 Enter 键时也能添加待办事项。这个案例展示了如何使用HTML、CSS和JavaScript来创建一个具有基本动态功能的网页应用。
除了上述的待办事项列表案例外,还有许多其他类似的JavaScript网页设计案例,这些案例展示了不同的功能和设计思路。以下是一些常见的案例及其简要描述:
(1)功能描述:
(2)代码示例(简化版):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Image Gallery</title>
<style>
.gallery img {
width: 100px; /* 或其他尺寸 */
height: auto;
margin: 10px;
cursor: pointer;
}
.modal {
display: none;
position: fixed;
z-index: 1;
/* 其他模态框样式 */
}
.modal-content {
/* 放大图片的样式 */
}
</style>
</head>
<body>
<div>
<img src="image1.jpg" alt="Image 1">
<img src="image2.jpg" alt="Image 2">
<!-- 更多图片 -->
</div>
<div>
<span>×</span>
<img>
</div>
<script>
// JavaScript 代码,用于处理点击事件和显示模态框
// ...(省略详细实现)
</script>
</body>
</html>
(1)功能描述:
(2)代码示例(简化版,需要替换API密钥):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Weather App</title>
</head>
<body>
<h1>Weather App</h1>
<input type="text" placeholder="Enter city">
<button>Get Weather</button>
<div></div>
<script>
const apiKey = 'YOUR_API_KEY'; // 替换为你的API密钥
document.getElementById('getWeather').onclick = function() {
const city = document.getElementById('cityInput').value;
fetch(`https://api.openweathermap.org/data/2.5/weather?q=${city}&appid=${apiKey}&units=metric`)
.then(response => response.json())
.then(data => {
const temp = data.main.temp;
const weatherDescription = data.weather[0].description;
document.getElementById('weatherResult').innerHTML = `Temperature: ${temp}°C<br>Description: ${weatherDescription}`;
})
.catch(error => {
document.getElementById('weatherResult').innerHTML = 'City not found.';
});
};
</script>
</body>
</html>
(1)功能描述:
(2)代码示例(由于篇幅限制,仅提供概念性描述):
这些案例涵盖了网页设计的不同方面,从基本的图片展示到实用的天气查询,再到动态的数据处理。它们都是学习JavaScript网页开发的良好起点,并可以根据实际需求进行扩展和定制。