2025年前端面试热门题目——HTML|CSS|Javascript|TS知识

以下是对这些 HTML 面试问题的详细解答:


1. HTML 的 srchref 属性有什么区别?

  • src (Source) 属性:

    • 用于嵌入资源,例如图像、脚本或 iframe。
    • 加载资源时,当前页面的加载会暂停,直到资源加载完成。
    • 常用于 <img><script><iframe> 标签。
    • 例子:
      <img src="image.jpg" alt="图片">
      <script src="script.js"></script>
      
  • href (Hypertext Reference) 属性:

    • 用于建立超链接,指向外部资源或内部的网页。
    • 不会暂停页面加载,用户可以点击链接跳转。
    • 常用于 <a><link><area> 标签。
    • 例子:
      <a href="https://example.com">访问示例网站</a>
      <link href="styles.css" rel="stylesheet">
      

2. 什么是 HTML 语义化?

HTML 语义化是指通过使用具有明确含义的标签,使 HTML 结构具有更好的可读性和意义。

  • 优点:

    1. 提高可读性:开发者和浏览器可以更轻松理解文档结构。
    2. 增强 SEO:语义化标签帮助搜索引擎更好地索引页面内容。
    3. 增强可访问性:辅助工具(如屏幕阅读器)可以更好地解释页面内容。
  • 常见语义化标签:

    • headerfooterarticlesection:定义页面结构。
    • nav:定义导航。
    • aside:定义侧边内容。
    • figurefigcaption:定义图像及其说明。

3. DOCTYPE(文档类型)的作用是什么?

  • 定义: DOCTYPE 声明用于告诉浏览器当前 HTML 文档的标准。
  • 作用:
    1. 让浏览器以标准模式(Standard Mode)渲染页面。
    2. 避免浏览器进入怪异模式(Quirks Mode),导致布局和样式出现问题。
  • HTML5 DOCTYPE 示例:
    <!DOCTYPE html>
    

4. HTML 的 script 标签中 deferasync 有什么区别?

  • defer

    • 脚本异步加载,并在 HTML 解析完成后按顺序执行。
    • 适合依赖 HTML 结构的脚本。
    • 示例:
      <script src="script.js" defer></script>
      
  • async

    • 脚本异步加载,加载完成后立即执行(可能在 HTML 未解析完成时执行)。
    • 适合独立的脚本(如广告或分析工具)。
    • 示例:
      <script src="script.js" async></script>
      
  • 区别总结:

    • defer 保证脚本按顺序执行,适用于多个依赖的脚本。
    • async 脚本独立,加载和执行更快。

5. 常用的 HTML meta 标签有哪些?

<meta> 标签用于定义页面的元信息,常用的有:

  • 字符编码:
    <meta charset="UTF-8">
    
  • 视口设置(适配移动端):
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    
  • 描述:
    <meta name="description" content="页面的描述内容">
    
  • 关键字:
    <meta name="keywords" content="HTML, CSS, JavaScript">
    
  • 作者信息:
    <meta name="author" content="作者名字">
    
  • 防止搜索引擎索引:
    <meta name="robots" content="noindex, nofollow">
    

6. HTML5 相比于 HTML有哪些更新?

  1. 新增语义化标签:

    • 如:<header><footer><article><section><nav>
  2. 新增表单功能:

    • 增加了新的输入类型:emailurldatenumber 等。
    • 表单属性:requiredplaceholderpattern
  3. 支持多媒体:

    • 新增 <audio><video> 标签。
  4. 新增 API:

    • 地理位置:Geolocation API
    • 本地存储:localStoragesessionStorage
    • 拖放:Drag and Drop API
    • 画布:<canvas> 标签。
  5. 废弃元素:

    • 移除了 <center><font> 等。

7. HTML 中,img 标签 srcset 属性的作用是什么?

  • 作用: 提供一组图像 URL 和其对应的显示条件,允许浏览器根据设备像素密度或屏幕宽度选择最合适的图像。
  • 示例:
    <img src="default.jpg" srcset="small.jpg 480w, medium.jpg 1024w" sizes="(max-width: 600px) 480px, 1024px" alt="图片">
    
    • 浏览器会根据视口大小和分辨率选择合适的图像。
    • 480w 表示图像宽度为 480 像素。

8. HTML 行内元素有哪些?块级元素有哪些?空 (void) 元素有哪些?

  • 行内元素:

    • 不占据独立一行,内容按行排列。
    • 常见:<a><span><img><strong><em><label>
  • 块级元素:

    • 独占一行,通常是容器。
    • 常见:<div><p><h1>~<h6><section><article><ul><li>
  • 空元素:

    • 没有闭合标签,只有单个标签。
    • 常见:<img><input><br><hr><meta>

9. HTML 中,titleh1 标签的区别是什么?

  • title 标签:

    • 定义网页的标题,显示在浏览器标签栏。
    • 对 SEO 友好,用于搜索引擎结果的标题。
    • 示例:
      <title>我的网页标题</title>
      
  • h1 标签:

    • 表示页面的主要标题。
    • 用于内容层次结构,通常一个页面只有一个 h1
    • 示例:
      <h1>欢迎来到我的网站</h1>
      

10. Canvas 和 SVG 有什么区别?

  • Canvas:

    • 基于像素的绘图。
    • 提供动态绘制能力,但不易修改内容。
    • 使用 JavaScript 绘制,适合实时动画和复杂图像处理。
    • 示例:
      <canvas id="myCanvas" width="200" height="100"></canvas>
      <script>
        const canvas = document.getElementById('myCanvas');
        const ctx = canvas.getContext('2d');
        ctx.fillStyle = 'red';
        ctx.fillRect(0, 0, 150, 75);
      </script>
      
  • SVG:

    • 基于 XML 的矢量图形。
    • 内容可以通过 DOM 轻松修改和操作。
    • 适合静态图形或需要高分辨率的图形。
    • 示例:
      <svg width="100" height="100">
        <circle cx="50" cy="50" r="40" fill="blue" />
      </svg>
      
  • 区别总结:

    • Canvas 注重像素,适合动画;SVG 注重结构,适合静态矢量图形。

如果需要进一步展开或补充某些问题,可以继续探讨!
以下是对这些 CSS 和 JavaScript 面试问题的详细解答:


1. 有哪些 CSS 选择器? 请分别介绍

CSS 选择器用于选择 HTML 元素以应用样式。常见选择器有:

  • 通配符选择器 (*)

    • 选择所有元素。
    • 示例:
      * {
        margin: 0;
        padding: 0;
      }
      
  • 类型选择器

    • 选择特定标签的元素。
    • 示例:
      p {
        color: blue;
      }
      
  • 类选择器 (.)

    • 选择特定类的元素。
    • 示例:
      .classname {
        font-size: 14px;
      }
      
  • ID 选择器 (#)

    • 选择特定 ID 的元素。
    • 示例:
      #idname {
        background-color: yellow;
      }
      
  • 属性选择器

    • 根据属性值选择元素。
    • 示例:
      input[type="text"] {
        border: 1px solid gray;
      }
      
  • 后代选择器 (A B)

    • 选择 B 元素,前提是它是 A 元素的后代。
    • 示例:
      div p {
        color: green;
      }
      
  • 子选择器 (A > B)

    • 选择 A 元素的直接子元素 B。
    • 示例:
      ul > li {
        list-style: none;
      }
      
  • 相邻兄弟选择器 (A + B)

    • 选择紧接在 A 后面的 B 元素。
    • 示例:
      h1 + p {
        font-size: 12px;
      }
      
  • 通用兄弟选择器 (A ~ B)

    • 选择与 A 同级的所有 B 元素。
    • 示例:
      h1 ~ p {
        color: gray;
      }
      
  • 伪类选择器

    • 选择元素的特定状态。
    • 示例:
      a:hover {
        text-decoration: underline;
      }
      
  • 伪元素选择器

    • 选择元素的特定部分。
    • 示例:
      p::first-line {
        font-weight: bold;
      }
      

2. 如何计算 CSS 的优先级?

CSS 优先级是用数字计算的,规则如下:

  1. 行内样式:1000
  2. ID 选择器:100
  3. 类选择器、伪类、属性选择器:10
  4. 标签选择器、伪元素:1
  5. 通配符、继承、默认样式:0

计算优先级的示例:

/* 优先级为:10 (类选择器) */
.class {
  color: red;
}

/* 优先级为:100 (ID 选择器) */
#id {
  color: blue;
}

/* 优先级为:101 (ID + 标签选择器) */
#id p {
  color: green;
}

规则:

  • 优先级高的样式覆盖优先级低的。
  • 同优先级时,后出现的覆盖前面的。

3. CSS 中可继承与不可继承属性有哪些?

  • 可继承属性:

    • 文本相关属性:
      • color
      • font 系列:font-familyfont-sizefont-style 等。
      • visibility
      • letter-spacingword-spacing
    • 默认行为:通过继承从父级传递到子级。
  • 不可继承属性:

    • 盒模型相关属性:
      • margin
      • padding
      • border
      • widthheight
      • box-shadow
    • 布局相关属性:
      • display
      • position
      • z-index
      • overflow
  • 强制继承:

    • 对于不可继承属性,可以通过 inherit 强制继承:
      div {
        width: inherit;
      }
      

4. CSS 中 display 属性的值及其作用

display 属性决定元素的显示方式。常见值:

  1. block

    • 块级元素,独占一行。
    • 示例:
      div {
        display: block;
      }
      
  2. inline

    • 行内元素,与其他元素共享一行。
    • 示例:
      span {
        display: inline;
      }
      
  3. inline-block

    • 具有行内特性,但可以设置宽高。
    • 示例:
      img {
        display: inline-block;
      }
      
  4. none

    • 隐藏元素,不占据空间。
    • 示例:
      p {
        display: none;
      }
      
  5. flex

    • 设为弹性布局容器。
    • 示例:
      div {
        display: flex;
      }
      
  6. grid

    • 设为网格布局容器。
    • 示例:
      div {
        display: grid;
      }
      

5. 使用 link@import 引用 CSS 的区别

  1. <link> 标签:

    • 在 HTML 文件中引入 CSS 文件。
    • 优点:支持并行加载,适合现代浏览器。
    • 示例:
      <link rel="stylesheet" href="style.css">
      
  2. @import 规则:

    • 在 CSS 文件中导入另一个 CSS 文件。
    • 缺点:浏览器需要解析 CSS 文件后再加载导入的文件,加载速度较慢。
    • 示例:
      @import url("style.css");
      

6. JavaScript 有哪些数据类型? 它们的区别是什么?

  • 基本数据类型 (Primitive Types):

    • stringnumberbigintbooleanundefinedsymbolnull
    • 特点:不可变、存储在栈中。
  • 引用数据类型 (Reference Types):

    • object (包括数组、函数等)。
    • 特点:可变、存储在堆中。

7. 如何判断 JavaScript 变量是数组?

  1. Array.isArray() (推荐):

    Array.isArray([1, 2, 3]); // true
    
  2. instanceof

    [1, 2, 3] instanceof Array; // true
    
  3. Object.prototype.toString

    Object.prototype.toString.call([1, 2, 3]); // "[object Array]"
    

8. JavaScript 中 nullundefined 的区别是什么?

  • null

    • 表示一个空的或无效的对象引用。
    • 需要手动赋值:
      let value = null;
      
  • undefined

    • 表示变量未初始化或不存在。
    • 系统自动赋值:
      let value; // 默认是 undefined
      

9. typeof null 的结果是什么? 为什么?

  • 结果:
    typeof null; // "object"
    
  • 原因:
    这是 JavaScript 的一个历史遗留问题,null 最初被设计为对象的特殊值,因此 typeof null 返回 "object"

10. typeofinstanceof 有什么区别?

  • typeof

    • 检测变量的数据类型。
    • 适合检查基本数据类型。
    • 示例:
      typeof 42; // "number"
      
  • instanceof

    • 检测对象是否是某个构造函数的实例。
    • 示例:
      [] instanceof Array; // true
      

总结:

  • typeof 主要用于基础类型判断。
  • instanceof 用于引用类型判断,尤其是继承关系的判断。
  • 以下是对这些 JavaScript 面试问题的详细解答:

1. 为什么 JavaScript 中 0.1 + 0.2 !== 0.3,如何让其相等?

原因:
  • JavaScript 使用 IEEE 754 双精度浮点数来表示数字,这种表示方式无法精确存储某些小数,例如 0.10.2
  • 计算过程中的精度损失导致:
    0.1 + 0.2; // 0.30000000000000004
    
解决方法:
  1. 使用 toFixed()toPrecision()

    • 将结果四舍五入到指定的小数位数。
    (0.1 + 0.2).toFixed(1); // "0.3"
    
  2. 使用乘除法避免小数计算:

    • 先将数字放大为整数计算,再缩小。
    (0.1 * 10 + 0.2 * 10) / 10 === 0.3; // true
    
  3. 使用 EPSILON 判断:

    • JavaScript 提供 Number.EPSILON 表示最小可区分值。
    Math.abs(0.1 + 0.2 - 0.3) < Number.EPSILON; // true
    

2. 说说你对 fetch 的理解,它有哪些优点和不足?

fetch 是什么?
  • fetch 是现代浏览器提供的原生 API,用于发起 HTTP 请求,返回一个基于 Promise 的结果。
优点:
  1. 语法简单:

    • 使用 Promise,代码更清晰。
    fetch(url)
      .then(response => response.json())
      .then(data => console.log(data))
      .catch(error => console.error(error));
    
  2. 原生支持:

    • 内置支持,不需要额外的库。
  3. 可扩展性:

    • 支持各种 HTTP 方法、头部设置、跨域请求等。
  4. 流式响应:

    • 支持 ReadableStream,适合处理大文件。
不足:
  1. 不支持超时控制:

    • 需要手动实现超时逻辑。
    const controller = new AbortController();
    setTimeout(() => controller.abort(), 5000); // 超时 5 秒
    fetch(url, { signal: controller.signal });
    
  2. 错误处理复杂:

    • fetch 仅在网络错误时抛出异常,HTTP 状态码错误(如 404、500)不会自动触发 catch
    fetch(url)
      .then(response => {
        if (!response.ok) {
          throw new Error('HTTP error ' + response.status);
        }
        return response.json();
      });
    
  3. 浏览器兼容性:

    • IE 不支持,需要 polyfill。

3. JavaScript 中 Object.keys 的返回值是无序的吗?

是否有序:
  • 根据规范:
    1. 如果对象的属性是数字键(索引),Object.keys 返回的数组按 升序 排列。
    2. 其他非数字键的属性按 插入顺序 返回。
  • 示例:
    const obj = { 1: 'one', 3: 'three', 2: 'two', a: 'A', b: 'B' };
    console.log(Object.keys(obj)); // ["1", "2", "3", "a", "b"]
    

4. JavaScript 的 BigInt 和 Number 类型有什么区别?

区别:
  1. 表示范围:

    • Number:安全整数范围为 -2^53 ~ 2^53(由 Number.MAX_SAFE_INTEGER 定义)。
    • BigInt:支持任意大小的整数。
  2. 操作:

    • BigInt 无法与 Number 混合运算。
    1n + 2; // TypeError
    1n + BigInt(2); // 3n
    
  3. 精度:

    • Number 是浮点类型,可能有精度损失。
    • BigInt 精确表示整数。
  4. 性能:

    • BigInt 操作效率较低。
示例:
console.log(Number.MAX_SAFE_INTEGER); // 9007199254740991
console.log(9007199254740991 + 1); // 9007199254740992 (精度丢失)
console.log(9007199254740991n + 1n); // 9007199254740992n (精确)

5. 什么是 JavaScript 的尾调用? 使用尾调用有什么好处?

尾调用:
  • 尾调用是指一个函数的最后一步调用另一个函数。
  • 尾调用条件:
    1. 调用是函数的最后一步。
    2. 返回调用的结果。
好处:
  • 减少内存占用:
    • 避免多余的调用栈帧,提升性能。
    • 对递归函数尤为重要(即尾递归优化)。
示例:
  • 普通递归(会累积调用栈):

    function factorial(n) {
      if (n === 1) return 1;
      return n * factorial(n - 1); // 不是尾调用
    }
    
  • 尾递归(优化调用栈):

    function factorial(n, acc = 1) {
      if (n === 1) return acc;
      return factorial(n - 1, acc * n); // 尾调用
    }
    

6. 使用 let 全局声明变量,能通过 window 对象取到吗?

  • 答案:不能。

  • 原因:

    • 使用 letconst 声明的全局变量不会成为 window 对象的属性。
    • 示例:
      let x = 10;
      console.log(window.x); // undefined
      
  • 对比:

    • 使用 var 声明的全局变量会成为 window 对象的属性。
    var y = 20;
    console.log(window.y); // 20
    

7. letconstvar 的区别是什么?

1. var
  • 作用域: 函数作用域。
  • 变量提升: 会提升至作用域顶部,默认值为 undefined
  • 可重复声明: 可以在同一作用域内多次声明。
2. let
  • 作用域: 块作用域。
  • 变量提升: 也会提升,但在提升前无法访问(称为“暂时性死区”)。
  • 不可重复声明: 同一作用域内不允许重复声明。
3. const
  • 作用域: 块作用域。
  • 常量: 声明时必须初始化,值不能重新赋值(对象属性可以修改)。
  • 不可重复声明: 同一作用域内不允许重复声明。

8. 说说你对 JS 作用域的理解?

1. 什么是作用域?

作用域是指代码中变量、函数或对象的可访问范围。

2. 分类:
  1. 全局作用域:

    • 定义在任何函数或块外的变量,具有全局可访问性。
    • 示例:
      var globalVar = "I am global";
      
  2. 函数作用域:

    • 使用 var 声明的变量在函数内部是局部的。
    • 示例:
      function scopeTest() {
        var localVar = "I am local";
        console.log(localVar);
      }
      
  3. 块作用域:

    • 使用 letconst 声明的变量只能在声明的块中访问。
    • 示例:
      if (true) {
        let blockVar = "I am block scoped";
        console.log(blockVar);
      }
      
3. 闭包与作用域:
  • 闭包是函数能够“记住”并访问其定义时的作用域。
  • 示例:
    function outer() {
      let outerVar = "I am outer";
      return function inner() {
        console.log(outerVar); // 闭包访问
      };
    }
    const fn = outer();
    fn(); // "I am outer"
    

    1. ES6 箭头函数和普通函数有什么区别?

1.1 语法上的区别:
  • 箭头函数更简洁,不需要 function 关键字:
    // 普通函数
    function sum(a, b) {
      return a + b;
    }
    
    // 箭头函数
    const sum = (a, b) => a + b;
    
1.2 特性上的区别:
  1. this 绑定规则:

    • 箭头函数没有自己的 this,会捕获其定义时的上下文 this
    • 普通函数的 this 根据调用方式动态绑定。
    const obj = {
      value: 10,
      arrowFunc: () => this.value, // 捕获定义时的上下文
      normalFunc() {
        return this.value; // 根据调用时绑定
      },
    };
    
    console.log(obj.arrowFunc()); // undefined (指向全局或模块的 this)
    console.log(obj.normalFunc()); // 10
    
  2. arguments 对象:

    • 箭头函数没有 arguments 对象,可以通过剩余参数代替。
    • 普通函数有 arguments,可以访问函数的实际参数。
    const arrowFunc = () => console.log(arguments); // Error
    function normalFunc() {
      console.log(arguments); // 可用
    }
    
  3. 作为方法或事件处理函数:

    • 箭头函数的 this 不会改变,适合绑定事件。
    • 普通函数会动态绑定,可能需要手动处理 this
    const obj = {
      value: 42,
      handler: () => console.log(this.value), // 指向全局或模块
    };
    document.body.addEventListener('click', obj.handler);
    
  4. 是否可作为构造函数:

    • 箭头函数不能作为构造函数。
    • 普通函数可以通过 new 操作符生成实例。

2. ES6 箭头函数能当构造函数吗?

答案:不能。
  • 箭头函数没有 [[Construct]] 内部方法,无法用 new 操作符调用。
  • 示例:
    const Arrow = () => {};
    const obj = new Arrow(); // TypeError: Arrow is not a constructor
    

3. ES6 有哪些新特性?

  1. 变量声明:letconst

    • 块作用域,避免变量提升。
    • 示例:
      let a = 10;
      const b = 20;
      
  2. 箭头函数

    • 简洁语法,自动绑定 this
    • 示例:
      const add = (a, b) => a + b;
      
  3. 模板字符串

    • 支持多行和嵌入表达式。
    • 示例:
      const greeting = `Hello, ${name}`;
      
  4. 解构赋值

    • 解构对象和数组。
    • 示例:
      const [a, b] = [1, 2];
      const { x, y } = { x: 3, y: 4 };
      
  5. 展开运算符 ...

    • 用于复制、合并或解构。
    • 示例:
      const arr = [...arr1, ...arr2];
      
  6. 默认参数

    • 函数参数支持默认值。
    • 示例:
      const greet = (name = 'Guest') => `Hello, ${name}`;
      
  7. 类和继承

    • 新增 classextends
    • 示例:
      class Person {
        constructor(name) {
          this.name = name;
        }
      }
      class Student extends Person {
        constructor(name, grade) {
          super(name);
          this.grade = grade;
        }
      }
      
  8. 模块化

    • 使用 importexport
    • 示例:
      import { foo } from './module.js';
      export const bar = 42;
      
  9. Promise

    • 用于异步编程。
    • 示例:
      const promise = new Promise((resolve, reject) => {
        resolve('Success');
      });
      
  10. SymbolMap/Set

    • 新的数据类型和数据结构。
    • 示例:
      const sym = Symbol('id');
      const map = new Map();
      

4. TypeScript 有哪些常用类型?

  1. 基本类型:

    • string, number, boolean, null, undefined, any, void, never.
  2. 数组类型:

    • number[]Array<number>
    • 示例:
      const nums: number[] = [1, 2, 3];
      
  3. 元组类型:

    • 固定长度、已知类型的数组。
    • 示例:
      const tuple: [number, string] = [42, 'Hello'];
      
  4. 枚举类型:

    • 定义一组命名常量。
    • 示例:
      enum Direction {
        Up,
        Down,
        Left,
        Right,
      }
      
  5. 对象类型:

    • 定义对象结构。
    • 示例:
      interface Person {
        name: string;
        age: number;
      }
      
  6. 联合类型:

    • 变量可为多种类型之一。
    • 示例:
      let value: string | number;
      
  7. 类型别名:

    • 定义自定义类型。
    • 示例:
      type ID = string | number;
      

5. 什么是 TypeScript 的对象类型? 怎么定义对象类型?

对象类型定义:
  • 在 TypeScript 中,对象类型是描述对象结构的类型。
  • 可以使用 interfacetype 定义对象类型。
定义方式:
  1. 使用接口 (interface):

    interface Person {
      name: string;
      age: number;
    }
    
    const user: Person = {
      name: 'Alice',
      age: 25,
    };
    
  2. 使用类型别名 (type):

    type Person = {
      name: string;
      age: number;
    };
    
    const user: Person = {
      name: 'Bob',
      age: 30,
    };
    
  3. 嵌套对象类型:

    interface Address {
      city: string;
      zipCode: number;
    }
    
    interface Person {
      name: string;
      address: Address;
    }
    
    const user: Person = {
      name: 'Charlie',
      address: {
        city: 'New York',
        zipCode: 10001,
      },
    };
    
  4. 可选属性和只读属性:

    interface Person {
      name: string;
      age?: number; // 可选
      readonly id: string; // 只读
    }
    
    const user: Person = {
      name: 'Diana',
      id: '12345',
    };
    
    // user.id = '54321'; // Error: Cannot assign to 'id' because it is a read-only property
    

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/942364.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

selenium执行js

JS知识 获取元素 document.getElement 移除属性&#xff1a;removeAttribute("xx") 窗口移动&#xff1a;window.scrollTo(0, document.body.scrollHeight)方法 drivier.execute_script(js)场景&#xff1a; 日期选择框&#xff0c;不能输入&#xff0c;只能设置…

三维场景重建与3D高斯点渲染技术探讨

&#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;编程探索专栏&#xff1a;点击&#xff01; ⏰️创作时间&#xff1a;2024年12月25日10点11分 神秘男子影, 秘而不宣藏。 泣意深不见, 男子自持重, 子夜独自沉。 文章源地址(有视频)&#xff1a;链接h…

springboot启动不了 因一个spring-boot-starter-web底下的tomcat-embed-core依赖丢失

这个包丢失了 启动不了 起因是pom中加入了 <tomcat.version></tomcat.version>版本指定&#xff0c;然后idea自动编译后&#xff0c;包丢了&#xff0c;删除这个配置后再也找不回来&#xff0c; 这个包正常在 <dependency><groupId>org.springframe…

Java日志框架:log4j、log4j2、logback

文章目录 配置文件相关1. properties测试 2. XMl使用Dom4j解析XML Log4j与Log4j2日志门面 一、Log4j1.1 Logges1.2 Appenders1.3 Layouts1.4 使用1.5 配置文件详解1.5.1 配置根目录1.5.2 配置日志信息输出目的地Appender1.5.3 输出格式设置 二、Log4j22.1 XML配置文件解析2.2 使…

基于LSTM长短期记忆神经网络的多分类预测【MATLAB】

在深度学习中&#xff0c;长短期记忆网络&#xff08;LSTM, Long Short-Term Memory&#xff09;是一种强大的循环神经网络&#xff08;RNN&#xff09;变体&#xff0c;专门为解决序列数据中的长距离依赖问题而设计。LSTM因其强大的记忆能力&#xff0c;广泛应用于自然语言处理…

机器学习基础 衡量模型性能指标

目录 1 前言 ​编辑1.1 错误率(Error rate)&精度(Accuracy)&误差(Error)&#xff1a; 1.2 过拟合(overfitting): 训练误差小&#xff0c;测试误差大 1.3 欠拟合(underfitting)&#xff1a;训练误差大&#xff0c;测试误差大 1.4 MSE: 1.5 RMSE: 1.6 MAE: 1.7 R-S…

TCP的流量控制的实现

滑动窗口的介绍 滑动窗口是tcp协议中的一个重要概念&#xff0c;滑动窗口是字节为单位&#xff0c;而tcp头部的序列化和确认号也是以字节为单位的&#xff0c;滑动窗口里是含有可以传输的字节的数量&#xff08;可以传输不是已经传输&#xff09;&#xff0c;而滑动窗口的大小是…

【0x001D】HCI_Read_Remote_Version_Information命令详解

目录 一、命令概述 二、命令格式及参数说明 2.12. HCI_Read_Remote_Version_Information 命令格式 2.2. Connection_Handle 三、生成事件 3.1. HCI_Command_Status 事件 3.2. HCI_Read_Remote_Version_Information_Complete 事件 四、命令执行流程 4.1. 命令发起阶段(…

一篇文章学会HTML

目录 页面结构 网页基本标签 图像标签 超链接标签 文本链接 图像链接 锚链接 功能链接 列表 有序列表 无序列表 自定义列表 表格 跨列/跨行 表头 媒体元素 视频 音频 网站的嵌套 表单 表单元素 文本框 单选框 多选框 按钮 下拉框 文本域和文件域 表…

C语言项目 天天酷跑(上篇)

前言 这里讲述这个天天酷跑是怎么实现的&#xff0c;我会在天天酷跑的下篇添加源代码&#xff0c;这里会讲述天天酷跑这个项目是如何实现的每一个思路&#xff0c;都是作者自己学习于别人的代码而创作的项目和思路&#xff0c;这个代码和网上有些许不一样&#xff0c;因为掺杂了…

如何完全剔除对Eureka的依赖,报错Cannot execute request on any known server

【现象】 程序运行报错如下&#xff1a; com.netflix.discovery.shared.transport.TransportException报错Cannot execute request on any known server 【解决方案】 &#xff08;1&#xff09;在Maven工程中的pom去掉Eureka相关的引用&#xff08;注释以下部分&#xff0…

华为云国内版与国际版的主要区别解析

华为云作为全球领先的云计算服务提供商&#xff0c;提供了国内版和国际版两种服务。虽然它们都旨在为用户提供高效、可靠的云计算解决方案&#xff0c;但在功能、服务、合规性等方面存在一些显著的区别。我们九河云通过本文将详细分析华为云国内版与国际版的主要区别&#xff0…

基于北斗短报文+4G的森林草原火险因子综合监测方案

近年来&#xff0c;全球气候变暖的趋势日益严重&#xff0c;气温升高导致森林火灾的发生频率和严重程度逐年增加&#xff0c;对人类社会和自然生态环境造成了严重的危害。森林火灾的发生受到植被类型、气象条件、扑救方式和监管方式等多种因素的影响。 因此&#xff0c;林业建…

小程序app封装公用顶部筛选区uv-drop-down

参考ui:DropDown 下拉筛选 | 我的资料管理-uv-ui 是全面兼容vue32、nvue、app、h5、小程序等多端的uni-app生态框架 样式示例&#xff1a; 封装公用文件代码 dropDownTemplete <template><!-- 顶部下拉筛选区封装公用组件 --><view><uv-drop-down ref&…

3 JDK 常见的包和BIO,NIO,AIO

JDK常见的包 java.lang:系统基础类 java.io:文件操作相关类&#xff0c;比如文件操作 java.nio:为了完善io包中的功能&#xff0c;提高io性能而写的一个新包 java.net:网络相关的包 java.util:java辅助类&#xff0c;特别是集合类 java.sql:数据库操作类 IO流 按照流的流向分…

Uniapp 手机基座调试App 打包成Apk文件,并上传到应用商店

1.Uniapp手机基座调试App。 1.1 以下是我另一篇文章 讲解 uniapp连接手机基座调试App、 Hbuildx使用SUB运行到手机基座测试_hbuilder基座-CSDN博客 2.打包本地的uniapp项目为apk文件。 打包的方式有很多种&#xff0c;我们可以选择本地打包和远程云端打包两种方式。 我们在打包…

vue调试工具 Vue.jsDevtools

文件下载 Vue.js Devtools 通过网盘分享的文件&#xff1a;ddebf336f8a44293bd4db9d0f287bc1c.crx 链接: https://pan.baidu.com/s/1uS3a49CwW-B000p5GwUQmQ 提取码: ko89 下载完了 &#xff0c;拖入chrome里&#xff0c;打开详情配置. 打开红框中的开关 重启浏览器&#xff…

数智化时代医院临床试验人才培养的创新路径与实践探索

一、引言 1.1 研究背景与意义 在当今数实化与智能化技术飞速发展的时代&#xff0c;医疗行业正经历着深刻的变革&#xff0c;数智化医院已成为未来发展的重要趋势。临床试验作为药物研发、医疗器械验证以及医疗技术创新的关键环节&#xff0c;对于推动医学进步、提高医疗质量…

产品更新 | 一网联千策:华望M-Cowork平台上的SysML模型协同管理

华望产品更新速递 功能介绍 | 协同平台M-Cowork的强大功能 ◆在线SysML建模与预览 ◆版本控制和基线管理 ◆可追溯的审签流程 ◆全面的系统管理 产品亮点 | 进一步了解协同平台M-Cowork ◆M-Cowork的管理功能 ◆M-Cowork的预览功能 ◆M-Cowork的审签流程 前言 在系统工…

纯相位全息图优化算法综述

◀ 背景引入 ▶ 近年来&#xff0c;得益于光学、电子和计算机等各项技术的进步以及新算法的不断提出&#xff0c;计算全息技术飞速发展。由于现有液晶空间光调制器对于纯相位全息图具有更高的调制能力与衍射效率&#xff0c;纯相位全息图优化算法一直以来都是研究热点。目前&…