如何在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日

相关文章

  • 详解JavaScript对象序列化

    我将详细讲解“详解JavaScript对象序列化”的完整攻略。 JavaScript对象序列化的概念 JavaScript对象序列化是指将JavaScript中的对象转换为字符串,以便于存储或传输,同时还可以将字符串反序列化为JavaScript对象,方便进行数据交换。 序列化方法 在JavaScript中,实现对象序列化有两种方法,分别是JSON.stri…

    JavaScript 2023年5月27日
    00
  • javascript 获取url参数的正则表达式(用来获取某个参数值)

    获取URL参数一直是前端开发的一个常见操作,JavaScript提供了多种方式来实现获取URL参数的功能,其中正则表达式是较为灵活且简单的一种方式。下面是获取URL参数的正则表达式及相应的代码示例: 正则表达式 以下正则表达式可以用来获取某个参数值: function getQueryString(name) { var reg = new RegExp(‘…

    JavaScript 2023年6月10日
    00
  • JS判断当前页面是否在微信浏览器打开的方法

    判断当前页面是否在微信浏览器打开的方法有多种,下面介绍其中比较常用的两种。 方法一: 使用”navigator.userAgent”判断当前浏览器的UserAgent是否包含”WeChat”关键词。 if(/micromessenger/.test(navigator.userAgent.toLowerCase())){ // 在微信浏览器中打开 }else…

    JavaScript 2023年6月11日
    00
  • JS常用字符串处理方法应用总结

    JS常用字符串处理方法应用总结 在JavaScript编程中,处理字符串是非常常见的操作。本篇文章将总结一些常用的字符串处理方法,并提供一些应用的示例。 一、字符串截取 1.1 substring方法 substring(startIndex, endIndex)方法可以截取指定开始和结尾位置的字符串,返回截取后的字符串。 示例: let str = &qu…

    JavaScript 2023年5月28日
    00
  • 基于JavaScript定位当前的地理位置

    下面是“基于JavaScript定位当前的地理位置”的完整攻略。 一、前提准备 在开始定位当前的地理位置之前,需要完成以下几个前提准备: 获取用户的位置需要用户授权,所以需要在web应用程序中使用HTML5的Geolocation API,而Geolocation只支持在HTTPS或者本地host环境下使用,所以需要对应用进行HTTPS协议的开发或者本地开发…

    JavaScript 2023年6月11日
    00
  • 教你如何使用 JavaScript 读取文件

    首先我们来讲一下使用 JavaScript 读取文件的基本步骤。 1. 创建一个 input 元素 <input type="file" id="inputFile"> 我们需要在 HTML 中创建一个 input 元素,并设置其 type 属性为 file,获取用户从本地计算机中选择的文件。 2. 监听 …

    JavaScript 2023年5月27日
    00
  • Vue联动Echarts实现数据大屏展示

    下面是“Vue联动Echarts实现数据大屏展示”的完整攻略。 一、什么是Vue联动Echarts Vue是一款流行的前端框架,Echarts是一款流行的数据可视化库。Vue联动Echarts的实现,就是将Vue与Echarts进行结合,实现数据的动态展示和交互。 二、如何实现Vue联动Echarts 1. 引入Echarts 在项目中引入Echarts库,…

    JavaScript 2023年6月11日
    00
  • jquery获取URL中参数解决中文乱码问题的两种方法

    接下来我将详细讲解“jquery获取URL中参数解决中文乱码问题的两种方法”的完整攻略。 问题描述 由于中国所有的编码都是基于 Unicode,因此 UTF-8 编码也经过传递被应用在了 URL 地址中。而浏览器在向服务器传递请求的时候,会自动将请求参数进行编码(包括中文),所以在 URL 中看起来是一堆乱码,而我们在使用 jQuery 获取 URL 中的参…

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