vscode编辑html框框,vscode插件开发记录---模式对话框

webview-panel.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(/( {

return $1 + vscode.Uri.file(path.resolve(dirPath, $2)).with({ scheme: 'vscode-resource' }).toString() + '"';

});

return html;

}

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

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值