技术标签: vue学习 前端功能 前端 vue.js javascript
目录
打开新页面,并实现在新开页面中携带参数,可以使用 URLSearchParams 对象,进行参数的拼接和解析,vue router跳转新页面和window.open都可以,几种方式适应于不同场景,URLSearchParams对象是结合window.open使用的。
使用 window.open()
可以在新窗口或新标签页中打开指定的 URL。
参数如下:
url
(可选):要在新窗口或新标签页中加载的页面的 URL。如果未提供此参数或为空字符串,则新窗口将打开一个空白页面。target
(可选):指定在哪里打开链接的目标窗口或标签页。常用的取值包括:
_blank
:在新标签页或新窗口中打开链接。_self
:在当前窗口中打开链接(默认行为)。_parent
:在父级窗口中打开链接。_top
:在顶级窗口中打开链接。- 自定义窗口名称:如果已经存在具有相同名称的窗口,则在该窗口中加载链接,否则会打开一个新的窗口。
windowFeatures
(可选):一个包含窗口特性的字符串(目前未在项目中使用过),用于指定新窗口的行为和外观。常用的特性包括:
width
:新窗口的宽度。height
:新窗口的高度。left
:新窗口的左侧位置。top
:新窗口的顶部位置。scrollbars
:是否显示滚动条。resizable
:新窗口是否可调整大小。fullscreen
:是否以全屏模式打开新窗口。- 等等。
示例:
//指定新窗口的名称、大小和其他选项window.open('https://www.example.com', '_blank', 'width=800, height=600');
// 在新标签页中打开指定 URL
window.open('https://www.example.com');
// 在具有特定名称的窗口中打开链接(如果不存在,则打开新窗口)
window.open('https://www.example.com', 'myWindow');
// 在指定大小的新窗口中打开链接
window.open('https://www.example.com', '_blank', 'width=800, height=600');
注意:由于浏览器的安全限制,对于弹出窗口的行为,大多数浏览器会进行阻止或拦截。为了避免被浏览器拦截,打开新窗口的操作必须是由用户的明确操作触发,例如点击按钮,有些如在点击某个链接后,获取一些参数,再跳转到某个地址的行为,可以按照以下进行:
setTimeout(() => window.open(url, "_blank"))
浏览器为了避免弹出广告影响用户,禁用了通过代码调用超链接在新标签打开页面的功能,所以必须是用户的明确行为,点击,长按等操作之类的,但把打开链接的操作放到setTimeout里运行,因为setTimeout是在主线程运行的,所以该操作不会被浏览器认定为代码操作的,所以不会拦截。
这个比较常见,一般跳转页面携带参数常用两种,query,params
// 字符串路径
router.push('/users/eduardo')
// 带有路径的对象
router.push({ path: '/users/eduardo' })
// 命名的路由,并加上参数,让路由建立 url
router.push({ name: 'user', params: { username: 'eduardo' } })
// 带查询参数,结果是 /register?plan=private
router.push({ path: '/register', query: { plan: 'private' } })
// 带 hash,结果是 /about#team
router.push({ path: '/about', hash: '#team' })
两者的区别:
Query Parameters(查询参数):Query参数是通过URL中的查询字符串来传递的,格式为
/path?key1=value1&key2=value2
。在Vue Router中,可以使用$route.query
来获取和操作查询参数。示例:
// 跳转到带查询参数的URL this.$router.push({ path: '/path', query: { key1: 'value1', key2: 'value2' } }); // 获取查询参数 console.log(this.$route.query.key1); // 输出:'value1'
query参数适合用于传递可选的、不敏感的参数,如搜索关键字、分页信息等。
URL Parameters(路径参数):Path参数是通过URL中的路径段来传递的,格式为
/path/:param1/:param2
。在Vue Router中,可以使用$route.params
来获取和操作路径参数。示例:
// 跳转到带路径参数的URL this.$router.push({ path: '/path/value1/value2' }); // 获取路径参数 console.log(this.$route.params.param1); // 输出:'value1'
params
参数适合用于传递必要的、敏感的参数,如资源ID、用户信息等。总结:
- query参数通过查询字符串传递,适合传递可选的、不敏感的参数。
params
参数通过路径段传递,适合传递必要的、敏感的参数。
创建一个 URLSearchParams 对象,并使用 append
方法向其中添加多个参数。然后,使用 toString
方法将 URLSearchParams 对象转换为查询字符串,并将其附加到 URL 上。
const params = new URLSearchParams(); params.append('param1', 'value1'); params.append('param2', 'value2'); params.append('param3', 'value3'); const url = `https://www.example.com/newpage?${params.toString()}`; window.open(url);
接收参数,两种方式都可以,如下:
要获取 URL 参数的值,可以使用
URLSearchParams
对象的get()
方法// 假设 URL 为 https://example.com/?name=John&age=25&city=New%20York const urlParams = new URLSearchParams(window.location.search); // 获取单个参数的值 const name = urlParams.get('name'); const age = urlParams.get('age'); const city = urlParams.get('city'); console.log(name); // 输出:John console.log(age); // 输出:25 console.log(city); // 输出:New York
在 Vue 3 中,可以使用
useRouter
方法来获取路由对象,然后通过query
或者params来获取 URL 参数。import { useRouter } from 'vue-router'; export default { setup() { const router = useRouter(); // 获取 URL 参数 const name = router.query.name; const age = router.query.age; const city = router.query.city; console.log(name); // 输出:John console.log(age); // 输出:25 console.log(city); // 输出:New York // 其他逻辑... return { // 返回组件的响应式数据和方法... }; } };
以上是几种常在开发中使用的几种跳转和新开页面的方式,关于router,在后续里需要更深入学习。
文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib
文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang
文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些
文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器
文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距
文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器
文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn
文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios
文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql
文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...
文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120
文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数