如何在VSCode Webview中打开一个新的页面

  上一篇我介绍了如何在VSCode Webview中实现点击链接下载图片或文件,本文介绍如何在默认浏览器中打开一个新的页面。

  在浏览器中,如果要实现打开一个新的页面有许多种不同的方法,例如:

window.open("https://www.cnblogs.com/jaxu", "_blank");

  或者直接在页面上放一个<a>标签:<a href="https://www.cnblogs.com/jaxu" target="_blank">点我</a>。当然这个标签也可以是动态生成的:

let a= document.createElement('a');
a.target= '_blank';
a.href= "https://www.cnblogs.com/jaxu";
a.click();

  但是这些方法在VSCode Webview中依然不工作,查看Developer Tools中的Console,会看到一行诸如"Blocked opening 'https://www.cnblogs.com/jaxu' in a new window because the request was made in a sandboxed frame whose 'allow-popups' permission is not set."的错误。看样子需要在Webview生成的iframe中添加allow-popups属性许可。我简单查了一下相关文档,对于如何添加allow-popups并没有比较具体的说明(如果有小伙伴找到了也可以在评论区中告知,多谢!)。

  参照我们在上一篇中的办法,打开一个新页面可以通过VSCode内置的Command openExternal在Server端来实现:

await vscode.env.openExternal(vscode.Uri.parse(sUrl));

  Client端可以通过响应标签的onclick事件直接调用Server端暴露出来的API来打开一个新的页面。只不过默认情况下VScode会弹出一个提示:

如何在VSCode Webview中打开一个新的页面

  点击Configure Trusted Domains可以将要打开的页面的domain保存起来,这样下次就不会再出提示了。

  Trusted Domains可以在VSCode的命令面板(Ctrl + Shift + P)中输入Manage Trusted Domains打开。该设置项貌似不是单独存放在一个配置文件中,而且好像也不能通过代码进行预先设置。感兴趣的同学可以查看下面这个文件:

如何在VSCode Webview中打开一个新的页面

  在VSCode的Webview中,有许多行为是受限制的,我猜这些限制也是出于安全方面的考虑。如果发现通过常规的方法无法实现所要的功能,那么可以查看一下VSCode内置的Command,看看有没有哪个Command提供了相同的功能。

 

原文链接:https://www.cnblogs.com/jaxu/p/17385999.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:如何在VSCode Webview中打开一个新的页面 - Python技术站

(0)
上一篇 2023年5月9日
下一篇 2023年5月10日

相关文章

  • js获取单选按钮的数据

    获取单选按钮的数据在实际应用中非常常见,以下是 js 获取单选按钮数据的完整攻略: 1. 获取单选按钮的选中状态 要获取单选按钮的数据,首先需要知道单选按钮的选中状态。单选按钮的选中状态可以通过其 checked 属性来获取。checked 属性是一个布尔值,表示单选按钮是否被选中。若该属性为 true,则表示单选按钮被选中。 下面是获取单选按钮的选中状态的…

    JavaScript 2023年6月10日
    00
  • JS作用域作用链及this使用原理详解

    JS作用域作用链及this使用原理详解 在JavaScript中,作用域和作用链是非常重要的概念,他们会影响变量和函数的调用、执行以及存储等方面。同时,this也是一个需要理解的重要概念,它在JavaScript中具有特殊的作用。本文将深入探讨这三个概念,并给出相关的示例。 作用域 作用域就是程序可以访问和操作的空间范围。在JavaScript中,每个函数都…

    JavaScript 2023年6月10日
    00
  • Mybatis常用分页插件实现快速分页处理技巧

    Mybatis常用分页插件实现快速分页处理技巧 背景 在使用Mybatis作为应用程序的ORM框架时,我们通常需要实现对数据库表的快速分页查询。而Mybatis常用的分页插件可以帮助我们快速实现这个功能。 准备工作 在使用分页插件之前,我们需要先将其引入到项目中,并在Mybatis的配置文件中进行配置。 引入分页插件 在Maven项目中,我们可以在pom.x…

    JavaScript 2023年6月10日
    00
  • javascript+php实现根据用户时区显示当地时间的方法

    实现根据用户时区显示当地时间的方法需要以下步骤: 获取用户的时区 使用Javascript的Date对象获取用户所在时区的偏移量。代码如下: var d = new Date(); var timezoneOffset = d.getTimezoneOffset() / 60; 其中getTimezoneOffset()方法返回的是分钟,所以需要将其转化为小…

    JavaScript 2023年6月11日
    00
  • JS表单验证方法实例小结【电话、身份证号、Email、中文、特殊字符、身份证号等】

    我们来详细讲解一下JS表单验证方法实例小结。 验证电话号码 function validatePhone(phone) { // 正则表达式验证手机号码,只允许输入数字,以 1 开头,总长度为 11 位 var reg = /^1\d{10}$/; return reg.test(phone); } 以上代码是一个验证电话号码的函数模板,其中使用了正则表达式…

    JavaScript 2023年6月10日
    00
  • JS实现点击登录弹出窗口同时背景色渐变动画效果

    JS实现点击登录弹出窗口同时背景色渐变动画效果可以分为以下几个步骤: HTML结构的修改:需要在HTML中添加一个按钮和一个弹窗,同时要添加一个全屏蒙层,作为背景色渐变的动画效果。 <button id="loginBtn">登录</button> <div id="loginModal"…

    JavaScript 2023年6月11日
    00
  • BOM系列第一篇之定时器setTimeout和setInterval

    BOM系列第一篇之定时器setTimeout和setInterval 一、概述 在前端开发中,我们经常需要在页面中加入一些动态效果,比如定时轮播图、倒计时等等,而这些效果往往需要用到JavaScript定时器。在JavaScript中,我们可以使用setTimeout()和setInterval()两个函数来实现定时器。 setTimeout()函数可以在一…

    JavaScript 2023年5月28日
    00
  • Ajax实现无刷新三联动下拉框

    介绍 本攻略将会详细介绍如何通过 Ajax 技术实现无刷新三联动下拉框。所谓三联动下拉框指的是三个下拉框之间存在父子关系,当父级下拉框的选项改变时,子级下拉框的选项会进行更新。 实现步骤 HTML 部分 首先,在 HTML 部分构建三个 select 标签,分别表示省市区县。 <select id="province"> &l…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部