下面我将提供一个简单的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" rel="external nofollow" > </head> <body> <h1>Todo List</h1> <input type="text" id="todoInput" placeholder="Add new todo..."> <button onclick="addTodo()">Add Todo</button> <ul id="todoList"> <!-- 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 class="gallery"> <img src="" alt="Image 1"> <img src="" alt="Image 2"> <!-- 更多图片 --> </div> <div id="modal" class="modal"> <span class="close">×</span> <img class="modal-content" id="modalImg"> </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" id="cityInput" placeholder="Enter city"> <button id="getWeather">Get Weather</button> <div id="weatherResult"></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网页开发的良好起点,并可以根据实际需求进行扩展和定制。
到此这篇关于Java Script网页设计案例的文章就介绍到这了,更多相关Java Script网页设计案例内容请搜索插件窝以前的文章或继续浏览下面的相关文章希望大家以后多多支持插件窝!