JavaScript获取地址栏参数的方法实现
需求
若地址栏URL为:code-nav/article/917?type=12&title=abc,我们要获取到地址栏后面的的type和title参数,如何才能拿到呢?
解决方案
1.原生JS实现:
1.1 采用正则表达式获取地址栏参数(第一种方法)
//获取地址栏参数,key:参数名称 function getUrlParams(key) { let reg = new RegExp("(^|&)" + key + "=([^&]*)(&|$)"); let r = window.location.search.substr(1) .match(reg); if (r != null) return unescape(r[2]); return null; } let title = getUrlParams("title"); // abc let type = getUrlParams("type"); // 12
1.2 传统方法截取实现(第二种方法)
//获取地址栏参数 function getUrlParams() { let url = window.location.search; //获取url中"?"符后的字串 let paramsObj = new Object(); if (url.indexOf("?") != -1) { let str = url.substr(1); strs = str.split("&"); for (let i = 0; i < strs.length; i++) { paramsObj[strs[i].split("=")[0]] = decodeURI(strs[i].split("=")[1]); } } return paramsObj; } let type = getUrlParams().type; // 12 let title = getUrlParams().title; // abc
2.Vue框架实现:
2.1 查询参数获取(场景一)
我们需要从地址code-nav/article/917?type=12&title=abc上拿到title的value abc。
<script setup> import {useRouter} from 'vue-router' const { currentRoute } = useRouter(); const route = currentRoute.value; onMounted(()=>{ let type=route.query.type console.log('type', type) // 12 }) </script>
2.2 获取路径参数(场景二)
我们需要从地址code-nav/article/917上拿到917这个参数。
首先需要在router/index.js中定义好路由以及路径参数,如下代码:
import { createRouter, createWebHistory } from 'vue-router' const router = createRouter({ history: createWebHistory(import.meta.env.BASE_URL), routes: [ { path: '/:id', name: 'home', component: () => import('../views/home.vue') }, ] }) export default router
接着就可以在home.vue组件中通过路由useRouter得到参数,注意是route.params,如下代码:
<script setup> import {useRouter} from 'vue-router' const { currentRoute } = useRouter(); const route = currentRoute.value; onMounted(()=>{ let id=route.params.id console.log('id', id) // 917 }) </script>
3.Angular框架实现:
3.1 矩阵URL参数获取(场景一)
参数拼接:
constructor( private router: Router, ) {} // 拼装 matrix url // code-nav/article;type=12;title=abc go() { this.router.navigate(['/code-nav/article', { type: 12, title: 'abc', }]); }
使用 this.route.params 或 this.route.paramMap 来获取 matrix URL 参数:
constructor( private route: ActivatedRoute ) { } ngOnInit() { // 获取参数, 使用 params this.route.params.subscribe(params => { console.log(params['type'],params['title']); }); // 使用 paramMap this.route.paramMap.subscribe(data => { console.log(data['params'].type,data['params'].title); }) }
3.2 传统获取(场景二)
snapshot , queryParams , queryParamMap
constructor( private route: ActivatedRoute ) { } ngOnInit() { // 获取参数, 使用 queryParams let param1 = this.route.snapshot.queryParams["title"]; let param2 = this.route.snapshot.queryParams["type"]; console.log(param1); console.log(param2); this.route.queryParams.subscribe(params => { console.log(params['title'],params['name']); }); // 获取参数, 使用 queryParamMap this.route.queryParamMap.subscribe(data => { const params = data['params']; console.log(params['title'],params['name']); }); }
4.React框架实现:
4.1 查询参数获取(场景一)
import { useParams } from "react-router-dom" export default function Order() { let params = useParams() return <h2>title: {params.title}</h2> }
总结
到此这篇关于JavaScript获取地址栏参数的方法实现的文章就介绍到这了,更多相关JS获取地址栏参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
javascript对下拉列表框(select)的操作实例讲解
这篇文章主要介绍了javascript对下拉列表框(select)的操作。需要的朋友可以过来参考下,希望对大家有所帮助2013-11-11
最新评论