【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。

简介: 【超实用】Angular如何修改当前页面网页浏览器url后面?param1=xxx&param2=xxx参数(多用于通过浏览器地址参数保存用户当前操作状态的需求),实现监听url路由切换、状态变化。

app.component.html

<button
(click)="
  location.go(
    'api/path',
    '?id=1&pageIndex=2&pageSize=10#hashValue2'
  );
  path1 = location.path(true);
  path2 = location.path(false)
"
>
【推荐使用】修改当前浏览器url路径,参数为多参数,并往所属平台(如浏览器)的历史堆栈中追加一个新条目
</button>
<br>
<button
  (click)="
    location.replaceState('', 'id=1#hashValue1');
    path1 = location.path(true);
    path2 = location.path(false)
  "
>
  修改当前浏览器url参数为单参数,并替换所属平台(如浏览器)的历史堆栈的顶部条目
</button>
<br />
<button
  (click)="
    location.replaceState(
      'api/path',
      '?id=1&pageIndex=2&pageSize=10#hashValue2'
    );
    path1 = location.path(true);
    path2 = location.path(false)
  "
>
  修改当前浏览器url路径,参数为多参数,并替换所属平台(如浏览器)的历史堆栈的顶部条目
</button>
<br />
<p style="color: red;">【含hash的url】{{ path1 }}</p>
<p style="color: red;">【不含hash的url】{{ path2 }}</p>
 
<hr />
 
<button (click)="path3 = normalizeQueryParams('a=1&b=2&c=3')">
  参数“a=1&b=2&c=3”前面加?
</button>
<p>【返回值】{{ path3 }}</p>
 
<hr />
 
<button (click)="path4 = joinWithSlash('path1', 'path2')">
  连接路径path1和path2
</button>
<p>【返回值】{{ path4 }}</p>
 
<hr />
 
<button (click)="path5 = stripTrailingSlash('/a/b/c/')">
  去掉“/a/b/c/”最后一个“/”
</button>
<p>【返回值】{{ path5 }}</p>
 
<hr />
 
<button (click)="state_str = getState()">报告位置历史记录的当前状态</button>
<p>{{ state_str }}</p>
 
<hr />
 
<button
  (click)="
  isEqual = location.isCurrentPathEqualTo(
      '/api/path',
      'id=1&pageIndex=2&pageSize=10'
    )
  "
>
  对指定的路径进行标准化,并和当前的标准化路径进行比较
</button>
<p>
  如果指定的 URL 路径和标准化之后的路径一样,则返回 true,否则返回
  false。【返回值】{{ isEqual }}
</p>
 
<hr />
 
<button (click)="path6 = location.normalize('/api/path/')">
  去掉“/api/path/”末尾斜杠
</button>
<p>【返回值】{{ path6 }}</p>
 
<hr />
 
<button (click)="path7 = location.prepareExternalUrl('api/path/')">
  在“api/path/”前加斜杠
</button>
<p>【返回值】{{ path7 }}</p>
 
<hr />
 
<button (click)=" location.forward()"> 前进 </button>
<button (click)=" location.back()"> 后退 </button> 
 
<hr />
 
<p style="color: green;">【监听路由变化】{{url}}</p>
<p style="color: green;">【监听路由状态】{{state}}</p>

app.component.ts

import { Component } from '@angular/core';
import {
  Location,
  LocationStrategy,
  PathLocationStrategy,
} from '@angular/common'; //引入获取、修改当前页面url相关参数的类
 
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.scss'],
  providers: [
    Location,
    { provide: LocationStrategy, useClass: PathLocationStrategy },//引入获取、修改当前页面url相关参数的类
  ],
})
export class AppComponent {
  constructor(
    public location: Location //引入获取、修改当前页面url相关参数的类
  ) {}
 
  path1 = '';
  path2 = '';
  path3 = '';
  path4 = '';
  path5 = '';
  path6 = '';
  path7 = '';
 
  state_str: any = '';
 
  isEqual = false;
 
  url = '';
  state: any = '';
 
  // 静态方法----------------------------------------
 
  //给定 URL 参数字符串,如果需要则增加 '?' 前缀,否则原样返回。
  normalizeQueryParams(params: string) {
    return Location.normalizeQueryParams(params);
  }
 
  //给定 url 的两个部分,把它们连接(join)在一起,如有必要则添加一个斜杠。
  joinWithSlash(start: string, end: string) {
    return Location.joinWithSlash(start, end);
  }
 
  //如果 url 具有结尾斜杠,则移除它,否则原样返回。 该方法会查找第一个 #、? 之前的结尾 / 字符,之后的则不管。如果 url 中没有 #、?,则替换行尾的。
  stripTrailingSlash(url: string) {
    return Location.stripTrailingSlash(url);
  }
 
  // 方法----------------------------------------
 
  /*
this.location.path() //返回标准化之后的 URL 路径
// ----------------------------------------
path(includeHash: boolean = false): string
参数
includeHash boolean
路径中是否包含一个锚点片段(Anchor fragment)。
可选. 默认值是 `false`.
返回值
标准化之后的 URL 路径。
*/
 
  // 报告位置历史记录的当前状态。
  getState() {
    return JSON.stringify(this.location.getState(), null, 2);
  }
 
  ngOnInit() {
    console.log(this.location);
    this.location.onUrlChange((url: string, state: unknown) => {
      (this.url = url), (this.state = JSON.stringify(state, null, 2));
      console.log(url, state);
    });
  }
}

浏览器渲染效果


相关文章
|
28天前
|
Java
Java开发实现图片URL地址检验,如何编码?
【10月更文挑战第14天】Java开发实现图片URL地址检验,如何编码?
59 4
|
11天前
|
缓存 网络协议 JavaScript
浏览器输入url之后最后网页渲染出来经过了什么
【10月更文挑战第31天】从浏览器输入 URL 到网页渲染出来是一个涉及多个环节和技术的复杂过程,每个环节都对最终的网页显示效果和用户体验有着重要的影响。
22 3
|
14天前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
16天前
|
域名解析 缓存 网络协议
浏览器中输入URL返回页面过程(超级详细)、DNS域名解析服务,TCP三次握手、四次挥手
浏览器中输入URL返回页面过程(超级详细)、DNS域名解析服务,TCP三次握手、四次挥手
|
22天前
|
Web App开发 Java
使用java操作浏览器的工具selenium-java和webdriver下载地址
【10月更文挑战第12天】Selenium-java依赖包用于自动化Web测试,版本为3.141.59。ChromeDriver和EdgeDriver分别用于控制Chrome和Edge浏览器,需确保版本与浏览器匹配。示例代码展示了如何使用Selenium-java模拟登录CSDN,包括设置驱动路径、添加Cookies和获取页面源码。
|
16天前
|
Java Spring
JAVA获取重定向地址URL的两种方法
【10月更文挑战第17天】本文介绍了两种在Java中获取HTTP响应头中的Location字段的方法:一种是使用HttpURLConnection,另一种是使用Spring的RestTemplate。通过设置连接超时和禁用自动重定向,确保请求按预期执行。此外,还提供了一个自定义的`NoRedirectSimpleClientHttpRequestFactory`类,用于禁用RestTemplate的自动重定向功能。
|
1月前
|
域名解析 缓存 负载均衡
网络浏览器并输入地址到显示的整个过程
网络浏览器并输入地址到显示的整个过程
|
1月前
|
缓存 网络协议 前端开发
浏览器输入一个URL后,发生了什么?
浏览器输入一个URL后,发生了什么?
25 1
|
30天前
|
域名解析 缓存 网络协议
浏览器输入 URL 回车后会经历哪些步骤?
本文首发于微信公众号“前端徐徐”,详细解析了从在浏览器中输入URL到页面完全呈现的全过程,涵盖检查缓存、URL解析、DNS解析、TCP连接、HTTP请求、服务器响应、浏览器处理响应、页面解析与渲染、关闭TCP连接等关键步骤。通过这些步骤,帮助读者深入了解互联网的工作原理,提升网站性能和用户体验。
16 0
|
2月前
|
JSON 前端开发 中间件
React读取properties配置文件转化为json对象并使用在url地址中
本文介绍了如何在React项目中读取properties配置文件,将其内容转化为JSON对象,并在请求URL地址时使用这些配置。文章详细说明了异步读取文件、处理字符串转换为JSON对象的过程,并提供了一个封装函数,用于在发起请求前动态生成配置化的URL地址。
75 1