WebView2中C#和JavaScript代码互操作

C#调用或者执行前端的JavaScript

    1.需要创建一个ScriptHost,并注册到WebView2中

  [ClassInterface(ClassInterfaceType.AutoDual)]
    [ComVisible(true)]
    /// <summary>
    /// 网页调用C#方法
    /// </summary>
    public class ScriptCallbackObject
//注册winning脚本c#互操作
WebViewCore.CoreWebView2.AddHostObjectToScript("winning", ScriptHost);
//注册全局变量winning
WebViewCore.CoreWebView2.AddScriptToExecuteOnDocumentCreatedAsync("var winning= window.chrome.webview.hostObjects.winning;");

    2.ScriptHost中暴露的公共方法,都可以在前端JavaScript中调用

 public MessageInfo GetMessageInfo()
        {
            return new MessageInfo()
            {
                Message = $"Message from .NET at {DateTime.Now:t}"
            };
        }
        public string PassMessageInfo(string jsonMessageInfo)
        {
            var msg = JsonConvert.DeserializeObject<MessageInfo>(jsonMessageInfo);
            string message = $"{msg.Message} {msg.Type} {msg.Number} {msg.IsActive}";
            return message;
        }

        public string ShowMessage(string arg)
        {
            //MessageBox.Show("【网页调用C#】:" + arg);
            //里面触发事件
            //返回到绑定的方法中
            OnScriptCallBack(arg);
            return "c#回调到前端";
            //要回调到前端
            //只需要在前端使用then(),默认异步方式执行
        }

 3.前端调用的C#代理默认都是异步,要同步调用需要加sync前缀 

winning.ShowMessage(titleText.value).then( function(msg) { alert(msg+'async'); }, 
                       function() { alert('failed'); })

function GetMessageInfo() {
		//window.chrome.webview.hostObjects.options.forceLocalProperties;
          var  msgObject=window.chrome.webview.hostObjects.sync.winning.GetMessageInfo();
		  var msg = "";
			for(var prop in msgObject) {
				 msg += prop +
				 ": " + msgObject[prop] +
					 "<br />";
			 }
			 msg = "Message Object is a Proxy - properties can't be iterated:<br/><br/>" + msg;

				 document.getElementById('MessageInfo').innerHTML =
        msgObject.Message +   // direct access works
        "<br/>" +
        msgObject.Number +
        "<br/>" +
        "Active: " +
        msgObject["IsActive"] +   // Property  Indexer works
        "<br/ ><br />" +
        msg;
	 }
passMessageInfo: function () {
		var msgObject = {
			Message: "Hello from JavaScript",
			Type: "Warning",
			Number: 20,
			IsActive: true
		}

		var json = JSON.stringify(msgObject);
		var msg = window.chrome.webview.hostObjects.sync.winning.PassMessageInfo(json);
		document.getElementById("MessageInfo").innerText = msg;
		}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值