本文详细介绍了前端编程学习中的HTML、CSS和JavaScript基础知识,包括标签使用、样式设置和基本语法。通过示例代码和实战项目,帮助读者理解和掌握这些技术。同时,文章还推荐了多个在线学习资源和社区,为前端编程学习提供了丰富的支持和指导。
HTML基础入门HTML(HyperText Markup Language)是一种用于创建网页的标准标记语言。HTML文档由一系列标签构成,这些标签描述了文档的结构、内容和样式。HTML标签通常由一对符号< >
包围,分为开始标签和结束标签。某些标签是自封闭标签,不需要结束标签。
<html>
:表示整个文档是一个HTML文档。<head>
:包含文档的元数据,如标题、样式表、脚本等。<body>
:包含文档的主体内容。<title>
:定义文档的标题,显示在浏览器的标签页上。<h1>
到<h6>
:表示标题,级别从高到低。<p>
:表示段落。<a>
:定义链接,用于导航到不同的页面或资源。<img>
:插入图片。<ul>
和<ol>
:无序和有序列表。<li>
:列表中的项目。<table>
、<tr>
、<td>
:用于创建表格。<!DOCTYPE html> <html> <head> <title>示例文档</title> </head> <body> <h1>这是标题</h1> <p>这是正文段落。</p> <a href="https://www.imooc.com/">访问慕课网</a> <img class="lazyload" src="" data-original="https://example.com/image.png" alt="示例图片"> <ul> <li>项目1</li> <li>项目2</li> </ul> <table> <tr> <td>行1,列1</td> <td>行1,列2</td> </tr> <tr> <td>行2,列1</td> <td>行2,列2</td> </tr> </table> </body> </html>
HTML文档的结构由<!DOCTYPE>
声明、<html>
、<head>
和<body>
标签组成。每个部分的作用如下:
<!DOCTYPE>
:声明文档类型,如HTML5。<html>
:根标签,包含整个文档。<head>
:包含元信息,如文档标题、字符集声明、元数据、链接的样式表、脚本文件等。<body>
:包含文档的内容,如文本、图片、链接、表格等。<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>示例文档</title> </head> <body> <h1>这是标题</h1> <p>这是正文段落。</p> </body> </html>
在实际项目中,开发者经常使用一些特定的HTML标签来构建复杂的网页。例如,使用表格、列表、表单等。
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>示例文档</title> </head> <body> <h1>表格示例</h1> <table border="1"> <tr> <th>姓名</th> <th>年龄</th> <th>性别</th> </tr> <tr> <td>张三</td> <td>23</td> <td>男</td> </tr> <tr> <td>李四</td> <td>25</td> <td>女</td> </tr> </table> <h1>列表示例</h1> <ul> <li>项目1</li> <li>项目2</li> </ul> <ol> <li>项目1</li> <li>项目2</li> </ol> <h1>表单示例</h1> <form action="/submit" method="post"> <label for="name">姓名:</label> <input type="text" id="name" name="name"> <br> <label for="age">年龄:</label> <input type="number" id="age" name="age"> <br> <input type="submit" value="提交"> </form> </body> </html>
CSS(Cascading Style Sheets)用于控制HTML元素的样式和布局。选择器用于指定需要应用样式规则的HTML元素。
p
、div
。:hover
、:active
。::before
、::after
。/* 元素选择器 */ p { color: blue; } /* 类选择器 */ .highlight { background-color: yellow; } /* ID选择器 */ #unique-element { font-weight: bold; } /* 选择器组合 */ p.highlight { text-decoration: underline; } /* 伪类选择器 */ a:hover { color: red; } /* 伪元素选择器 */ div::before { content: "前缀"; }
CSS样式规则由选择器和一组声明组成。声明由属性和值构成。
font-family
:设置字体。font-size
:设置字体大小。color
:设置文本颜色。background-color
:设置背景颜色。padding
:设置内边距。margin
:设置外边距。width
、height
:设置元素的宽度和高度。/* 基本属性 */ p { font-family: "宋体"; font-size: 16px; color: black; background-color: lightgrey; padding: 10px; margin: 20px; width: 200px; height: 100px; }
CSS提供了多种布局方式,如float
、position
和flex
布局。响应式设计通过媒体查询来适应不同的屏幕尺寸。
float
:通常用于布局元素,如图片。position
:用于绝对定位或相对定位,如relative
、absolute
、fixed
。flex
布局:通过display: flex
来实现灵活的布局。媒体查询
:通过@media
规则来检测屏幕尺寸并调整布局。/* flex 布局 */ .container { display: flex; flex-direction: row; justify-content: space-around; } .item { width: 100px; height: 100px; background-color: lightcoral; margin: 10px; } /* 媒体查询 */ @media screen and (max-width: 600px) { .container { flex-direction: column; } }
JavaScript是一种动态类型语言,变量可以存储各种类型的数据。
var
:基本的变量声明。let
:块级作用域变量声明。const
:常量声明,值不可更改。string
、number
、boolean
、undefined
、null
、object
、function
、symbol
。// 声明变量 var message = "Hello, World!"; let count = 123; const PI = 3.14159; // 数据类型 console.log(typeof message); // string console.log(typeof count); // number console.log(typeof PI); // number console.log(typeof undefined); // undefined console.log(typeof null); // object console.log(typeof {}); // object console.log(typeof function() {}); // function console.log(typeof Symbol('foo')); // symbol
JavaScript提供了多种控制结构和函数来控制程序的执行流程。
if
语句:根据条件执行代码块。switch
语句:根据变量值执行不同的代码块。for
、while
、do-while
循环:重复执行代码块。function
:函数声明关键字。=>
:箭头函数。return
:返回函数结果。// if 语句 var age = 18; if (age >= 18) { console.log("成年人"); } else { console.log("未成年人"); } // switch 语句 var day = "Monday"; switch (day) { case "Monday": console.log("星期一"); break; default: console.log("其他"); } // for 循环 for (let i = 0; i < 5; i++) { console.log(i); } // while 循环 let i = 0; while (i < 5) { console.log(i); i++; } // do-while 循环 let j = 0; do { console.log(j); j++; } while (j < 5); // 函数 function greet(name) { return "Hello, " + name; } console.log(greet("Alice")); // 箭头函数 const greet2 = name => `Hello, ${name}`; console.log(greet2("Bob"));
DOM(Document Object Model)是浏览器解析HTML文档后生成的对象模型。JavaScript可以通过DOM API来操作HTML文档。
document.getElementById
:通过ID获取元素。document.querySelector
:通过CSS选择器获取元素。element.innerHTML
:设置或获取元素的HTML内容。element.addEventListener
:添加事件监听器。// 获取元素 const elementById = document.getElementById("myDiv"); const elementByQuery = document.querySelector(".myClass"); // 设置HTML内容 elementById.innerHTML = "<p>新的内容</p>"; // 添加事件监听器 elementById.addEventListener("click", function() { console.log("元素被点击了"); }); // 事件冒泡 document.body.addEventListener("click", function(event) { console.log("body 被点击了"); });
构建个人简历网站的目标是展示个人基本信息、教育背景、工作经验、技能和项目经验。简历网站通常包含以下内容:
创建基本的HTML结构,包括导航栏、内容区域、页脚等。
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>个人简历</title> <link rel="stylesheet" href="styles.css"> </head> <body> <header> <h1>张三的个人简历</h1> <nav> <ul> <li><a href="#about">基本信息</a></li> <li><a href="#education">教育背景</a></li> <li><a href="#experience">工作经验</a></li> <li><a href="#skills">技能</a></li> <li><a href="#projects">项目经验</a></li> </ul> </nav> </header> <main> <section id="about"> <h2>基本信息</h2> <p>姓名:张三</p> <p>联系方式:1234567890</p> <p>个人简介:...描述...</p> </section> <section id="education"> <h2>教育背景</h2> <ul> <li> <p>学历:本科</p> <p>专业:计算机科学</p> <p>学校:清华大学</p> <p>毕业时间:2010年</p> </li> </ul> </section> <section id="experience"> <h2>工作经验</h2> <ul> <li> <p>公司:阿里云</p> <p>职位:前端开发工程师</p> <p>时间:2010-2012</p> <p>职责:...描述...</p> </li> </ul> </section> <section id="skills"> <h2>技能</h2> <ul> <li>HTML/CSS</li> <li>JavaScript</li> <li>React</li> </ul> </section> <section id="projects"> <h2>项目经验</h2> <ul> <li> <p>项目名称:电商平台</p> <p>描述:电商平台</p> <p>时间:2012-2014</p> <p>职责:...描述...</p> </li> </ul> </section> </main> <footer> <p>© 2023 张三</p> </footer> </body> </html>
使用CSS美化简历网站,包括导航栏、内容区域、页脚等。
/* 基本样式 */ body { font-family: Arial, sans-serif; margin: 0; padding: 0; } header { background-color: #333; color: white; padding: 20px; } nav ul { list-style: none; padding: 0; } nav ul li { display: inline; margin-right: 10px; } nav ul li a { color: white; text-decoration: none; } main { padding: 20px; } section { margin-bottom: 20px; } footer { background-color: #333; color: white; text-align: center; padding: 10px; position: fixed; bottom: 0; width: 100%; }
使用JavaScript实现简历网站的一些交互功能,如导航栏的滚动效果、点击事件等。
document.addEventListener("DOMContentLoaded", function() { const links = document.querySelectorAll("nav ul li a"); const sections = document.querySelectorAll("section"); links.forEach(link => { link.addEventListener("click", function(event) { event.preventDefault(); const targetId = this.getAttribute("href"); const targetSection = document.querySelector(targetId); scrollToSection(targetSection); }); }); function scrollToSection(section) { const offsetTop = section.offsetTop; window.scrollTo({ top: offsetTop, behavior: "smooth" }); } });
文本编辑器和集成开发环境(IDE)是前端开发中的基本工具。常用的编辑器有VS Code、Sublime Text、Atom,而IDE有WebStorm。
代码版本控制系统帮助开发者管理和追踪代码的变化,常用的工具有Git、SVN。
浏览器开发者工具提供了强大的功能来调试和测试前端代码,包括Chrome DevTools、Firefox Developer Tools。