从输入URL到页面展示过程:深入解析网络请求与渲染

标签: url 页面 展示 | 发表时间:2023-08-31 09:33 | 作者:desc
出处:https://juejin.cn/tag/%E6%9E%B6%E6%9E%84

推荐阅读

项目实战:AI文本 OCR识别最佳实践

AI Gamma一键生成PPT工具直达链接

玩转cloud Studio 在线编码神器

玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间

资源分享

史上最全文档AI绘画stablediffusion资料分享

AI绘画关于SD,MJ,GPT,SDXL百科全书

AI绘画 stable diffusion Midjourney 官方GPT文档 AIGC百科全书资料收集

  「java、python面试题」来自UC网盘app分享,打开手机app,额外获得1T空间
https://drive.uc.cn/s/2aeb6c2dcedd4
AIGC资料包
https://drive.uc.cn/s/6077fc42116d4
https://pan.xunlei.com/s/VN_qC7kwpKFgKLto4KgP4Do_A1?pwd=7kbv#

引言

在当今互联网时代,我们每天都会通过浏览器访问各种网页。但是,你是否曾经思考过在我们输入一个URL后,浏览器是如何加载并显示页面的呢?这背后涉及到一系列复杂的技术和过程。本文将带领大家深入了解从输入URL到页面展示的过程,并给出相应的代码示例,让我们一起探索这个神奇而又复杂的世界。

1. 网络请求的发起

通过浏览器输入URL后,浏览器会根据协议类型(如HTTP或HTTPS)向服务器发起请求。这个过程可以通过下面的代码示例来体现:

  const url = "https://example.com";
fetch(url)
  .then(response => response.text())
  .then(data => {
    console.log(data);
  })
  .catch(error => {
    console.error(error);
  });

在代码中,我们使用了JavaScript的fetch API来发起网络请求,并将服务器响应转换为文本输出到控制台。

2. DNS解析

在发送网络请求前,浏览器首先需要将URL中的域名解析成对应的IP地址。这个过程称为DNS解析。下面是一个简化版的DNS解析示例代码:

  const dns = require('dns');

const domain = "example.com";
dns.resolve(domain, 'A', (err, addresses) => {
  if (err) {
    console.error(err);
    return;
  }
  console.log(addresses);
});

上述代码中,我们使用Node.js的 dns模块来进行DNS解析,并输出解析得到的IP地址。

3. 建立TCP连接

经过DNS解析后,浏览器会尝试与服务器建立TCP连接。这个过程涉及到三次握手,确保数据能够安全可靠地传输。以下是一个简化的TCP连接代码示例:

  const net = require('net');

const serverIP = '192.168.0.1';
const port = 80;

const client = new net.Socket();
client.connect(port, serverIP, () => {
  console.log('TCP connection established');
});

在上述代码中,我们使用Node.js的 net模块创建了一个TCP socket,并通过 connect方法与服务器建立连接。

4. 发送HTTP请求

TCP连接建立后,浏览器会构建HTTP请求并发送给服务器。以下是一个简化的HTTP请求发送代码示例:

  const http = require('http');

const options = {
  hostname: 'example.com',
  port: 80,
  path: '/',
  method: 'GET'
};

const req = http.request(options, res => {
  console.log(`HTTP response status code: ${res.statusCode}`);
});

req.end();

在上述代码中,我们使用Node.js的 http模块创建了一个HTTP请求,并通过 request方法发送给服务器。

5. 服务器处理请求

服务器收到浏览器发送的HTTP请求后,会根据请求的内容进行相应的处理。这个过程通常包括路由解析、数据查询等操作。下面是一个简化的服务器处理请求的代码示例:

  const http = require('http');

const server = http.createServer((req, res) => {

  if (req.url === '/') {

res.writeHead(200, { 'Content-Type': 'text/plain' });

res.end('Hello, World!');

  } else if (req.url === '/about') {

res.writeHead
(200, { 'Content-Type': 'text/html' });
    res.end('<h1>About Page</h1>');
  } else {
    res.writeHead(404, { 'Content-Type': 'text/plain' });
    res.end('Page not found');
  }
});

server.listen(80, () => {
  console.log('Server running at http://localhost:80/');
});

在上述代码中,我们使用Node.js的 http模块创建了一个简单的HTTP服务器。根据请求的URL路径,服务器会返回不同的响应内容。

6. 接收响应数据

当服务器处理完请求并生成响应后,浏览器会接收到响应数据。这个过程在浏览器内部进行,我们无法直接访问其代码。浏览器会将响应数据存储在缓存中,并准备进行后续的解析和渲染。

7. 解析HTML

浏览器接收到响应数据后,会对HTML进行解析,构建出一棵DOM树。这个过程包括识别HTML标签、属性、文本等,并将其转换为可以操作的数据结构。以下是一个简化的HTML解析代码示例:

  const parser = new DOMParser();
const htmlString = '<html><head><title>Hello, World!</title></head><body><h1>Welcome</h1></body></html>';
const doc = parser.parseFromString(htmlString, 'text/html');

console.log(doc.title); // Output: "Hello, World!"
console.log(doc.body.innerHTML); // Output: "<h1>Welcome</h1>"

在上述代码中,我们使用JavaScript的DOMParser来解析HTML字符串,并通过操作解析后的DOM树来获取需要的信息。

8. 构建DOM树

浏览器在解析HTML后,会根据标签之间的层次关系构建一棵DOM树。每个HTML元素都会被转换为DOM节点,并按照其在HTML中的嵌套关系形成父子节点的层次结构。以下是一个简化的DOM树构建示例:

  const htmlString = '<html><head><title>Hello, World!</title></head><body><h1>Welcome</h1></body></html>';
const doc = new DOMParser().parseFromString(htmlString, 'text/html');

console.log(doc.documentElement); // Output: HTML元素节点
console.log(doc.documentElement.childNodes.length); // Output: 2,包含<head>和<body>
console.log(doc.documentElement.childNodes[1].childNodes[0]); // Output: <h1>Welcome</h1>

在上述代码中,我们使用DOMParser来解析HTML字符串,并通过访问 documentElementchildNodes属性来获取DOM树的节点信息。

9. 渲染页面

经过DOM树的构建后,浏览器会根据DOM树的结构和样式信息对页面进行渲染。这个过程包括布局计算、绘制元素、加载外部资源等操作,最终将页面显示给用户。由于浏览器的渲染过程非常复杂,我们无法直接操作其渲染引擎。但是,我们可以通过调试工具来观察页面的渲染情况。

10. 用户交互与动态效果

在页面渲染完成后,用户可以与页面进行交互,并享受丰富的动态效果。这包括点击链接、提交表单、触发事件等操作。JavaScript在此起到了重要的作用,它可以监听用户的操作并相应地更新页面内容或执行相应的逻辑。

11. 性能优化

为了提供更好的用户体验,我们需要关注性能优化。这包括减少网络请求次数、压缩资源文件、使用缓存等策略。同时,优化JavaScript和CSS的编写方式也可以提升页面的加载速度和响应性能。

相关 [url 页面 展示] 推荐:

从输入URL到页面展示过程:深入解析网络请求与渲染

- - 掘金 架构
项目实战:AI文本 OCR识别最佳实践. AI Gamma一键生成PPT工具直达链接. 玩转cloud Studio 在线编码神器. 玩转 GPU AI绘画、AI讲话、翻译,GPU点亮AI想象空间. 史上最全文档AI绘画stablediffusion资料分享. AI绘画关于SD,MJ,GPT,SDXL百科全书.

URL的井号

- chenqj - 阮一峰的网络日志
一个显著变化,就是URL加入了"#!"符号. 在我印象中,这是主流网站第一次将"#"大规模用于直接与用户交互的关键URL中. 这表明井号(Hash)的作用正在被重新认识. 本文根据HttpWatch的文章,整理与井号有关的所有重要知识点. 其右面的字符,就是该位置的标识符. 就代表网页index.html的print位置.

将URL编码?

- - JavaScript - Web前端 - ITeye博客
    URL一般只能由字母、数字、$ - _. * ' ( ) 等一些字符构成. 那么当URL中需要用到汉字时怎么办,譬如有这样的URL: "www.test.com/search?name=张三",此时,只有通过将URL进行编码的方式进行传递了.     Javascript编/解码方法:.     如果对上面的URL(www.test.com/search?name=张三)进行编码的话.

从输入 URL 到页面加载完成的过程中都发生了什么事情

- - 互联网 - ITeye博客
本文来自于之前我发的一篇微博:. 不过写这篇文章并不是为了帮大家准备面试,而是想借这道题来介绍计算机和互联网的基础知识,让读者了解它们之间是如何关联起来的. 为了便于理解,我将整个过程分为了六个问题来展开. 第一个问题:从输入 URL 到浏览器接收的过程中发生了什么事情. 首先是「输入 URL」,大部分人的第一反应会是键盘,不过为了与时俱进,这里将介绍触摸屏设备的交互.

理清URL编码

- winners - Thinking for Fun
关于URL编码,RFC1738做了如下的规定:. “Only alphanumerics [0-9a-zA-Z], the special characters “$-_.+!*’(),” [not including the quotes - ed], and reserved characters used for their reserved purposes may be used unencoded within a URL.”.

iOS UIWebView URL拦截

- - 移动开发 - ITeye博客
本文译者: candeladiao,原文: URL filtering for UIWebView on the iPhone. 说明:译者在做app开发时,因为页面的javascript文件比较大导致加载速度很慢,所以想把javascript文件打包在app里,当UIWebView需要加载该脚本时就从app本地读取,但UIWebView并不支持加载本地资源.

URL最大长度问题

- - CSDN博客推荐文章
这几天为解决一个BUG头疼了一段时间,BUG现象如下:. 一个选择人员的选择控件,当选择多个人时(50多个的时候),返回没有错误现象,而再一次打开的时候就报404错误. 看到这个错误非常纳闷,无法下手,只能再一次看控件的代码,在详细看代码时,发现所有的参数都是经过URL传参的,赶紧百度一下URL参数的大小限制(从这个百度开始,我就进入一个误区:参数大小的限制).

URL中井号的作用

- - CSDN博客Web前端推荐文章
  URL中的井号(#)是比较常见的,它并不影响网址的指向,而是有众多功能和特点的. 下面就为大家介绍一些有关井号的故事.   1、页面中的某一个位置可以用井号在URL中指定.   井号作为比较长出现在URL的一种符号,通常也会代表这个页面中的某一个位置,比如:http://aoshu.juren.com/chzt/xiaoxueshijuan/index.html#nn1,此URL表示在这个页面中nn1的位置.

APP调用Custom URL Scheme

- - IT技术博客大学习
标签:   Scheme   跳转. Custom URL scheme 的好处就是,你可以在其它程序中通过这个url打开应用程序. 如A应用程序注册了一个url scheme:myApp,  那么就在mobile浏览器中就可以通过打开你的应用程序A. 首先在AndroidManifast.xml要被指定Scheme的Activity下设置如下参数.