廢話少說,直接上代碼:
第一步:
第二步:
第三步:
第四步:
App.xaml.cs對應的代碼:
using CefSharp; using CefSharp.Wpf; using System; using System.IO; using System.Reflection; using System.Runtime.CompilerServices; using System.Windows; namespace CefSharpe { /// <summary> /// App.xaml 的交互邏輯 /// </summary> public partial class App : Application { public App() { //Add Custom assembly resolver AppDomain.CurrentDomain.AssemblyResolve += Resolver; //Any CefSharp references have to be in another method with NonInlining // attribute so the assembly rolver has time to do it's thing. InitializeCefSharp(); } [MethodImpl(MethodImplOptions.NoInlining)] private static void InitializeCefSharp() { var settings = new CefSettings(); // Set BrowserSubProcessPath based on app bitness at runtime settings.BrowserSubprocessPath = Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase, Environment.Is64BitProcess ? "x64" : "x86", "CefSharp.BrowserSubprocess.exe"); // Make sure you set performDependencyCheck false Cef.Initialize(settings, performDependencyCheck: false, browserProcessHandler: null); } // Will attempt to load missing assembly from either x86 or x64 subdir // Required by CefSharp to load the unmanaged dependencies when running using AnyCPU private static Assembly Resolver(object sender, ResolveEventArgs args) { if (args.Name.StartsWith("CefSharp")) { string assemblyName = args.Name.Split(new[] { ',' }, 2)[0] + ".dll"; string archSpecificPath = Path.Combine(AppDomain.CurrentDomain.SetupInformation.ApplicationBase, Environment.Is64BitProcess ? "x64" : "x86", assemblyName); return File.Exists(archSpecificPath) ? Assembly.LoadFile(archSpecificPath) : null; } return null; } } }
以上實現的是cefsharp支持any cpu
下面實現加載本地html並且實現與js交互,對於如何下載cefsharp就不做過多說明,網上一大把
第五步:
<Window x:Class="CefSharpe.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:CefSharpe" xmlns:cefSharp="clr-namespace:CefSharp.Wpf;assembly=CefSharp.Wpf" mc:Ignorable="d" Title="cefSharp" > <Grid> <cefSharp:ChromiumWebBrowser x:Name="cefsharp"></cefSharp:ChromiumWebBrowser> <Button Height="30" VerticalAlignment="Bottom" Click="Button_Click">調用js的方法</Button> </Grid> </Window>
第六步:
using CefSharp; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; using System.IO; using System.Reflection; using System.Runtime.CompilerServices; using CefSharp.Wpf; namespace CefSharpe { /// <summary> /// MainWindow.xaml 的交互邏輯 /// </summary> public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); CefSharpSettings.LegacyJavascriptBindingEnabled = true; this.cefsharp.Address = AppDomain.CurrentDomain.BaseDirectory+@"index.html"; this.cefsharp.RegisterJsObject("JsObj", new CallbackObjectForJs(), new CefSharp.BindingOptions { CamelCaseJavascriptNames = false});
//阻止默認行為 cefsharp.MenuHandler = new MenuHandler(); } public class CallbackObjectForJs { public string name = ""; public void showTest(string msg) { MessageBox.Show(msg); MessageBox.Show(name); } } private void Button_Click(object sender, RoutedEventArgs e) { cefsharp.ExecuteScriptAsync("ydb1('asdadaasdasdas我是楊道波')"); } public class MenuHandler : IContextMenuHandler { public void OnBeforeContextMenu(IWebBrowser browserControl, IBrowser browser, IFrame frame, IContextMenuParams parameters, IMenuModel model) { model.Clear(); } public bool OnContextMenuCommand(IWebBrowser browserControl, IBrowser browser, IFrame frame, IContextMenuParams parameters, CefMenuCommand commandId, CefEventFlags eventFlags) { return false; } public void OnContextMenuDismissed(IWebBrowser browserControl, IBrowser browser, IFrame frame) { } public bool RunContextMenu(IWebBrowser browserControl, IBrowser browser, IFrame frame, IContextMenuParams parameters, IMenuModel model, IRunContextMenuCallback callback) { return false; } } } }
第七步:
在本地項目中放入index.html
第八步:
index.html里面的內容
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h1 id="ydb">我是楊道波sdadsad</h1> <!--<script>--> <!--//屏蔽鼠標右鍵、Ctrl+N、Shift+F10、F11、F5刷新、退格鍵--> <!--document.oncontextmenu = function () { event.returnValue = false; }//屏蔽鼠標右鍵--> <!--window.onhelp = function () { return false } //屏蔽F1幫助--> <!--document.onkeydown = function () {--> <!--if ((window.event.altKey) &&--> <!--((window.event.keyCode == 37) || //屏蔽 Alt+ 方向鍵 ←--> <!--(window.event.keyCode == 39))) { //屏蔽 Alt+ 方向鍵 →--> <!--event.returnValue = false;--> <!--return false;--> <!--}--> <!--/* 注:這還不是真正地屏蔽Alt+方向鍵,--> <!--因為Alt+方向鍵彈出警告框時,按住Alt鍵不放,--> <!--用鼠標點掉警告框,這種屏蔽方法就失效了。*/--> <!--if ((event.keyCode == 8) || //屏蔽退格刪除鍵--> <!--(event.keyCode == 116) || //屏蔽 F5 刷新鍵--> <!--(event.ctrlKe && event.keyCode == 82)) { //Ctrl + R--> <!--event.keyCode = 0;--> <!--event.returnValue = false;--> <!--}--> <!--if (event.keyCode == 122) { event.keyCode = 0; event.returnValue = false; } //屏蔽F11--> <!--if (event.ctrlKey && event.keyCode == 78) event.returnValue = false; //屏蔽Ctrl+n--> <!--if (event.shiftKey && event.keyCode == 121) event.returnValue = false; //屏蔽shift+F10--> <!--if (window.event.srcElement.tagName == "A" && window.event.shiftKey)--> <!--window.event.returnValue = false; //屏蔽shift加鼠標左鍵新開一網頁--> <!--if ((window.event.altKey) && (window.event.keyCode == 115)) { //屏蔽Alt+F4--> <!--window.showModelessDialog("about:blank", "", "dialogWidth:1px;dialogheight:1px");--> <!--return false;--> <!--}--> <!--}--> <!--</script>--> <script> ydb.onclick = function(){ JsObj.name = "asdsadasdas"; JsObj.showTest("test"); } function ydb1(msg) { alert(msg) } </script> </body> </html>
效果展示:
點擊文字:
點擊名為(調用js的方法)的按鈕:
拿走不謝.
這是要把我一個學前端逼的轉行的節奏啊.