vscode插件开发记录---模式对话框

举报
Amrf 发表于 2020/07/13 17:42:02 2020/07/13
【摘要】 主体参考:https://www.cnblogs.com/liuxianan/p/vscode-plugin-webview.htmlwebview-panel.ts:https://github.com/ayqy/browser/blob/a0b2cba5a59924debb4c2a0456ff0802d2c15d95/src/WebviewPanel.ts修改一下静态方法createOr...

主体参考:https://www.cnblogs.com/liuxianan/p/vscode-plugin-webview.html

webview-panel.ts:

https://github.com/ayqy/browser/blob/a0b2cba5a59924debb4c2a0456ff0802d2c15d95/src/WebviewPanel.ts

修改一下静态方法createOrShow,添加一些参数

 message: any,//用于消息显示类型的对话框

position: vscode.WebviewModalPosition,//对话框显示的位置

 config:any,//用于传入对话框输入项的默认值

callback:any//function(pConfig){} 对框框点击确定后的回调

对话框初始化参数通过message['xx'] = xxx;message['cmd'] = "initParam";WebviewPanel.currentPanel.postMessage(message);形式传给webview,对应的webview页面如果采用vuejs开发则,组件created中window.addEventListener('message', this.onMessage),然后根据message.cmd执行初始化;反向的消息通讯参考callVscode,

webview : vscode.postMessage({ key: "close" }) ==》 webviewpanel.ts: message.key === "close" this.dispose();

webview : callVscode({ cmd: 'saveSetting', config: this.config }, () => { this.alert('保存成功!');});==》webviewpanel.ts: this._callback(message);this.dispose();

值得注意的是webview中的资源引入需要webview-panel.ts中添加支持(参考第一个链接)

    private _getWebViewContent(templatePath: string): string {
        const resourcePath: string = path.join(this._basePath, templatePath);
        //const resourcePath = util.getExtensionFileAbsolutePath(context, templatePath);
        const dirPath = path.dirname(resourcePath);
        let html = fs.readFileSync(resourcePath, 'utf-8');
        // vscode不支持直接加载本地资源,需要替换成其专有路径格式,这里只是简单的将样式和JS的路径替换
        html = html.replace(/(<link.+?href="|<script.+?src="|<img.+?src=")(.+?)"/g, (m, $1, $2) => {
            return $1 + vscode.Uri.file(path.resolve(dirPath, $2)).with({ scheme: 'vscode-resource' }).toString() + '"';
        });
        return html;
    }


表单的样式采用引入的bootstrap支持,其他的只是一些细节调整;

/----------------------------------------------------------------------------------------------------------------------------------------/

依照上面这种思路:webview页面中vscode.postMessage,panel.webview.onDidReceiveMessage中处理消息,我们还可以做一些点击页面元素关联跳转文件行或者一些其他的native功能;



【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。