本文详细解析了前端基础知识,包括HTML、CSS和JavaScript的使用,并提供了大量的前端面试真题及解答,帮助读者深入理解前端技术。此外,文章还涵盖了Vue.js和React.js的基本使用方法,以及算法和数据结构在前端面试中的应用。本文旨在帮助读者准备前端面试,掌握前端面试真题。
HTML(HyperText Markup Language)用于构建网页的结构,是网页的基础。HTML文档由元素构成,每个元素由标签定义。元素可以嵌套,形成复杂的结构。以下是一些常用的HTML标签示例:
基本结构标签
<html>
:HTML文档的根标签。<head>
:文档头部,包含元数据(如<title>
)。<body>
:文档的主体,包含网页内容。<title>
:设置网页标题,显示在浏览器标签上。文本内容标签
<p>
:段落。<a>
:超链接。<strong>
:加粗文本。<em>
:斜体文本。<code>
:代码片段。<pre>
:预格式化文本。列表标签
<ul>
:无序列表。<ol>
:有序列表。<li>
:列表项。表格标签
<table>
:表格。<tr>
:表格行。<td>
:表格数据单元。<th>
:表格标题单元。<form>
:表单。<input>
:表单元素,可以是输入框、复选框、单选按钮等。<textarea>
:多行文本输入框。<button>
:按钮。<select>
:下拉列表。示例代码:
<!DOCTYPE html> <html> <head> <title>示例页面</title> </head> <body> <h1>欢迎来到示例页面</h1> <p>这是一段普通的文本。</p> <a href="https://www.imooc.com/">慕课网</a> <ul> <li>第一个列表项</li> <li>第二个列表项</li> </ul> <table> <tr> <th>姓名</th> <th>年龄</th> <th>城市</th> </tr> <tr> <td>张三</td> <td>28</td> <td>北京</td> </tr> <tr> <td>李四</td> <td>32</td> <td>上海</td> </tr> </table> <form> <input type="text" placeholder="输入框"> <button type="submit">提交</button> </form> </body> </html>
CSS(Cascading Style Sheets)用于控制网页的样式,为网页添加视觉效果。以下是一些常用的CSS选择器和属性示例:
选择器
div
:选择所有<div>
元素。.class
:基于类选择器选择特定元素。#id
:基于ID选择器选择特定元素。h1, h2
:选择多个标签。color
:设置文本颜色。background-color
:设置背景颜色。font-size
:设置字体大小。margin
:设置外边距。padding
:设置内边距。border
:设置边框。width
和 height
:设置元素的宽度和高度。display
:控制元素的显示方式(如block
、inline
、flex
)。示例代码:
<!DOCTYPE html> <html> <head> <style> body { background-color: #f0f0f0; font-family: Arial, sans-serif; } h1 { color: #333; font-size: 24px; margin: 10px; } .highlight { background-color: yellow; border: 1px solid black; padding: 5px; } .flex-container { display: flex; justify-content: space-around; height: 100px; } </style> </head> <body> <h1>示例标题</h1> <div class="highlight">这是一个高亮的段落。</div> <div class="flex-container"> <div style="background-color: red;">红色</div> <div style="background-color: blue;">蓝色</div> <div style="background-color: green;">绿色</div> </div> </body> </html>
JavaScript是一种广泛使用的编程语言,用于添加交互性到网页。以下是一些JavaScript的基础概念和示例代码:
var
、let
、const
:用于声明变量。typeof
:用于检查变量类型。var num = 5; // Number let str = "Hello"; // String const bool = true; // Boolean console.log(typeof num); // 输出 "number" console.log(typeof str); // 输出 "string" console.log(typeof bool); // 输出 "boolean"
function greet(name) { return "Hello, " + name + "!"; } console.log(greet("Alice")); // 输出 "Hello, Alice!"
// 获取元素 var element = document.getElementById("myElement"); // 设置文本 element.textContent = "新文本"; // 设置属性 element.setAttribute("class", "newClass");
<button id="myButton">点击我</button> <script> var button = document.getElementById("myButton"); button.addEventListener("click", function() { alert("按钮被点击了"); }); </script>
Promise
或async/await
处理异步操作。function fetchUser() { return new Promise(function(resolve, reject) { setTimeout(function() { resolve({ id: 1, name: "Alice" }); }, 2000); }); } async function getUser() { try { var user = await fetchUser(); console.log(user.name); // 输出 "Alice" } catch (error) { console.error("获取用户失败"); } } getUser();
DOM(Document Object Model)是网页的结构模型,允许通过JavaScript操作网页元素。BOM(Browser Object Model)是浏览器的结构模型,提供操作浏览器窗口的方法。
DOM操作
document.getElementById()
、document.querySelector()
。element.textContent
、element.setAttribute()
。document.createElement()
。element.parentNode.removeChild(element)
。element.addEventListener()
。event.stopPropagation()
。示例代码:
var button = document.getElementById("myButton"); button.addEventListener("click", function() { console.log("按钮被点击了"); });
CSS选择器
:hover
、:active
、:focus
。:before
、:after
。@media (max-width: 768px)
。示例代码:
@media (max-width: 768px) { body { background-color: #ccc; } } .container { display: flex; justify-content: space-between; align-items: center; }
数组操作
Array.prototype.indexOf()
。Array.prototype.sort()
。Array.prototype.filter()
。Array.prototype.map()
。Array.prototype.reduce()
。示例代码:
function binarySearch(arr, target) { let start = 0; let end = arr.length - 1; while (start <= end) { let mid = Math.floor((start + end) / 2); if (arr[mid] === target) { return mid; } else if (arr[mid] < target) { start = mid + 1; } else { end = mid - 1; } } return -1; }
this
关键字
this
关键字在不同环境中指向不同的对象。this
指向调用函数的对象。this
指向新创建的对象。this
继承自外层作用域。示例代码:
function Person(name) { this.name = name; } Person.prototype.sayHello = function() { console.log("Hello, " + this.name); }; var p = new Person("Alice"); p.sayHello(); // 输出 "Hello, Alice"
示例代码:
function createCounter() { var count = 0; return function() { count++; return count; }; } var counter = createCounter(); console.log(counter()); // 输出 1 console.log(counter()); // 输出 2
.then()
方法可以链式调用多个Promise。.then()
返回一个新的Promise。示例代码:
function fetchData() { return new Promise(function(resolve, reject) { setTimeout(function() { resolve("数据"); }, 2000); }); } fetchData() .then(function(data) { console.log(data); // 输出 "数据" return fetchData(); }) .then(function(data) { console.log(data); // 输出 "数据" });
解释原型和原型链
prototype
。[[Prototype]]
指向其原型。capture
参数控制事件捕获或冒泡。<script class="lazyload" src="" data-original="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
npm install vue
new Vue()
创建Vue实例。el
属性指定挂载点。data
属性定义数据。methods
属性定义方法。mounted
生命周期钩子。示例代码:
<div id="app"> {{ message }} <button v-on:click="changeMessage">点击我</button> </div> <script> new Vue({ el: "#app", data: { message: "Hello, Vue!" }, methods: { changeMessage: function() { this.message = "我被点击了"; } }, mounted: function() { console.log("Vue实例已挂载"); } }); </script>
<script class="lazyload" src="" data-original="https://unpkg.com/react@16/umd/react.development.js"></script> <script class="lazyload" src="" data-original="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script>
npm install react react-dom
class
定义组件。setState
更新状态。render
方法渲染组件。componentDidMount
生命周期钩子。示例代码:
<div id="app"></div> <script> class App extends React.Component { constructor(props) { super(props); this.state = { message: "Hello, React!" }; } changeMessage = () => { this.setState({ message: "我被点击了" }); } componentDidMount() { console.log("React组件已渲染"); } render() { return ( <div> {this.state.message} <button onClick={this.changeMessage}>点击我</button> </div> ); } } ReactDOM.render(<App />, document.getElementById("app")); </script>
解释Vue和React的生命周期
beforeCreate
、created
、beforeMount
、mounted
、beforeUpdate
、updated
、beforeDestroy
、destroyed
。constructor
、componentDidMount
、componentDidUpdate
、componentWillUnmount
。示例代码:
<div id="app"> {{ message }} {{ uppercaseMessage }} <input v-model="message"> </div> <script> new Vue({ el: "#app", data: { message: "Hello, Vue!" }, computed: { uppercaseMessage: function() { return this.message.toUpperCase(); } }, watch: { message: function(newVal, oldVal) { console.log("message从" + oldVal + "变为" + newVal); } } }); </script>
示例代码:
function binarySearch(arr, target) { let start = 0; let end = arr.length - 1; while (start <= end) { let mid = Math.floor((start + end) / 2); if (arr[mid] === target) { return mid; } else if (arr[mid] < target) { start = mid + 1; } else { end = mid - 1; } } return -1; }
示例代码:
function quickSort(arr) { if (arr.length <= 1) { return arr; } let pivot = arr[Math.floor(arr.length / 2)]; let left = []; let right = []; let equal = []; for (let num of arr) { if (num < pivot) { left.push(num); } else if (num > pivot) { right.push(num); } else { equal.push(num); } } return [...quickSort(left), ...equal, ...quickSort(right)]; }
数组
push
、pop
、splice
等。对象
栈和队列
push
和pop
。enqueue
和dequeue
。示例代码:
// 栈实现 class Stack { constructor() { this.items = []; } push(item) { this.items.push(item); } pop() { return this.items.pop(); } peek() { return this.items[this.items.length - 1]; } isEmpty() { return this.items.length === 0; } } // 队列实现 class Queue { constructor() { this.items = []; } enqueue(item) { this.items.push(item); } dequeue() { return this.items.shift(); } peek() { return this.items[0]; } isEmpty() { return this.items.length === 0; } }
充分准备
简历准备
示例简历摘录:
姓名:张三 邮箱:zhangsan@example.com 联系方式:12345678900 GitHub:https://github.com/zhangsan 技能: - HTML/CSS/JavaScript - Vue.js/React.js - Git 项目经验: - 项目名称:在线商城 - 使用Vue.js构建前端界面 - 优化页面性能,提升用户体验 - 负责与后端API接口的对接
示例自我介绍:
大家好,我叫张三,是一名前端开发工程师。我对HTML、CSS和JavaScript有深入的理解,熟练使用Vue.js和React.js构建前端应用。我有丰富的项目经验,曾参与开发在线商城项目,优化了页面性能,提升了用户体验。我的GitHub主页是https://github.com/zhangsan,欢迎大家访问。谢谢。