当前位置: 首页 > news >正文

wordpress 函数大全排名优化网站

wordpress 函数大全,排名优化网站,西安app制作设计公司,舆情分析网站Blazor 混合开发_MAUIVue_WPFVue 背景混合开发的核心为什么必须使用 wwwroot 文件夹放置 Web 项目文件 创建 MAUI 项目创建 wwwroot 文件夹服务注册创建 _import.razor添加 Main.razor 组件修改 MainPage.xaml 文件 创建 WPF 项目创建 wwwroot 文件夹服务注册创建 _import.razo… Blazor 混合开发_MAUIVue_WPFVue 背景混合开发的核心为什么必须使用 wwwroot 文件夹放置 Web 项目文件 创建 MAUI 项目创建 wwwroot 文件夹服务注册创建 _import.razor添加 Main.razor 组件修改 MainPage.xaml 文件 创建 WPF 项目创建 wwwroot 文件夹服务注册创建 _import.razor添加 Shell.razor 组件修改 MainWindow.xaml 文件 创建 Vue 项目修改创建好的 Vue 项目执行 npm run build 命令Copy dist修改 index.html 内容 效果预览Demo 下载 背景 在 MAUI 微软的官方方案是使用 Blazor 开发但是当前市场大多数的 Web 项目使用 Vue、React 等技术构建用Blazor重写整个项目并不现实。   Vue 是当前流行的 Web 框架 简单来说是一套模板引擎利用 “模板” 和 “绑定” 两大特性实现Web页面 MVVM 模式开发。利用 .NET MAUI 框架可以将 Vue 应用嵌入到 Web 容器中可以实现跨平台的混合开发。 混合开发的核心 混合开发的核心工作是构建 Web 与 .NET 的互操作我们将利用 Blazor 引擎的如下功能 资源的统一管理js 代码的注入js 调用 C# 代码C# 调用 js 代码 为什么必须使用 wwwroot 文件夹放置 Web 项目文件 这个文件夹将是混合开发Web部分的根目录这个名称不能随便定义 Microsoft.AspNetCore.Components.WebView.Maui 库会将 wwwroot 文件夹里的内容作为 Maui 资源MauiAsset类型设置标签编译器则会根据 MauiAsset 标签将这些内容打包进各个平台的资源文件夹。 创建 MAUI 项目 项目名字 MAUI.Vue.hybirddev 创建完成后编辑Hybrid.Maui.csproj在Sdk最末尾加上.RazorVS 会自动安装Microsoft.AspNetCore.Components.WebView.Maui 依赖包 不要手动 Nuget 添加这个包否则程序无法运行 创建 wwwroot 文件夹 创建之后会自动变成网络资源文件夹 服务注册 使用扩展方法 builder.Services.AddMauiBlazorWebView() 对 BlazorMauiWebView 组件服务进行注册 using Microsoft.Extensions.Logging;namespace MAUI.Vue.hybirddev {public static class MauiProgram{public static MauiApp CreateMauiApp(){var builder MauiApp.CreateBuilder();builder.UseMauiAppApp().ConfigureFonts(fonts {fonts.AddFont(OpenSans-Regular.ttf, OpenSansRegular);fonts.AddFont(OpenSans-Semibold.ttf, OpenSansSemibold);});builder.Services.AddMauiBlazorWebView(); // 注册#if DEBUGbuilder.Services.AddBlazorWebViewDeveloperTools();builder.Logging.AddDebug(); #endifreturn builder.Build();}} }创建 _import.razor 添加 → 类 → Razor 组件 导入 namespace using System.Net.Http using System.Net.Http.Json using Microsoft.AspNetCore.Components.Forms using Microsoft.AspNetCore.Components.Routing using Microsoft.AspNetCore.Components.Web using Microsoft.AspNetCore.Components.Web.Virtualization using Microsoft.JSInterop using Hybrid.Maui *当前项目名称*添加 Main.razor 组件 被JS调用的方法必须是静态的Dispose 销毁页面资源防止内存溢出 inject IJSRuntime JSRuntime implements IDisposablecode {[JSInvokable]public static Taskstring Test(){return Task.FromResult(Maui Test Function);}public void Dispose(){} }修改 MainPage.xaml 文件 建立 BlazorWebView 控件铺满屏幕并设置 HostPage 为Web部分的主页 index.html ?xml version1.0 encodingutf-8 ? ContentPagex:ClassHybrid.Maui.MainPagexmlnshttp://schemas.microsoft.com/dotnet/2021/mauixmlns:xhttp://schemas.microsoft.com/winfx/2009/xamlxmlns:localclr-namespace:Hybrid.MauiShell.NavBarIsVisibleFalseBlazorWebView HostPagewwwroot/index.htmlBlazorWebView.RootComponentsRootComponent ComponentType{x:Type local:Main} Selector#blazorApp //BlazorWebView.RootComponents/BlazorWebView/ContentPage创建 WPF 项目 项目名字 Hybrid.Wpf 创建完成后编辑Hybrid.Wpf.csproj在Sdk最末尾加上.Razor 同时在项目文件的现有 PropertyGroup 中添加 RootNamespaceHybrid.Wpf/RootNamespace 标记 安装 Nuget 包 Microsoft.AspNetCore.Components.WebView.Wpf 创建 wwwroot 文件夹 创建之后会自动变成网络资源文件夹 服务注册 通过依赖注入容器注入 AddWpfBlazorWebView() 服务在资源中添加已注册的服务 Resources.Add(services, Services)删除App.xaml 中的 StartupUriMainWindow.xaml using System.Windows; using Microsoft.Extensions.DependencyInjection;namespace Hybrid.Wpf {/// summary/// Interaction logic for App.xaml/// /summarypublic partial class App : Application{public App(){Services ConfigureServices();Resources.Add(services, Services);}public new static App Current (App)Application.Current;public IServiceProvider Services { get; }protected override void OnStartup(StartupEventArgs e){Services.GetRequiredServiceMainWindow().Show();}private static IServiceProvider ConfigureServices(){var serviceCollection new ServiceCollection();serviceCollection.AddSingletonMainWindow();serviceCollection.AddWpfBlazorWebView();#if DEBUGserviceCollection.AddBlazorWebViewDeveloperTools(); #endifreturn serviceCollection.BuildServiceProvider();}} }创建 _import.razor 添加 → 类 → Razor 组件 导入 namespace using System.Net.Http using System.Net.Http.Json using Microsoft.AspNetCore.Components.Forms using Microsoft.AspNetCore.Components.Routing using Microsoft.AspNetCore.Components.Web using Microsoft.AspNetCore.Components.Web.Virtualization using Microsoft.JSInterop using Hybrid.Wpf *Object Namespace*添加 Shell.razor 组件 被JS调用的方法必须是静态的Dispose 销毁页面资源防止内存溢出 inject IJSRuntime JSRuntime implements IDisposablecode {[JSInvokable]public static Taskstring Test(){return Task.FromResult(Wpf Test Function);}public void Dispose(){} }修改 MainWindow.xaml 文件 建立 BlazorWebView 控件铺满屏幕并设置 HostPage 为Web部分的主页 index.html Windowx:ClassHybrid.Wpf.MainWindowxmlnshttp://schemas.microsoft.com/winfx/2006/xaml/presentationxmlns:xhttp://schemas.microsoft.com/winfx/2006/xamlxmlns:blazorclr-namespace:Microsoft.AspNetCore.Components.WebView.Wpf;assemblyMicrosoft.AspNetCore.Components.WebView.Wpfxmlns:dhttp://schemas.microsoft.com/expression/blend/2008xmlns:localclr-namespace:Hybrid.Wpfxmlns:mchttp://schemas.openxmlformats.org/markup-compatibility/2006TitleHybrid.Wpfd:Height200d:Width450WindowStartupLocationCenterScreenmc:Ignorabledblazor:BlazorWebView HostPagewwwroot\index.html Services{DynamicResource services}blazor:BlazorWebView.RootComponentsblazor:RootComponent ComponentType{x:Type local:Shell} Selector#blazorApp //blazor:BlazorWebView.RootComponents/blazor:BlazorWebView/Window创建 Vue 项目 通过命令 npm create vuelatest 前提是已安装 Node.js 执行命令尝试运行项目 修改创建好的 Vue 项目 DotNet.invokeMethodAsync(Hybrid.Maui, Test) 第一个参数是容器项目的 Namespace第二个参数是要调用的方法。 script setup import { RouterLink, RouterView } from vue-router; import HelloWorld from ./components/HelloWorld.vue;/*** 访问 Hybrid.Wpf 项目中的 Test 方法*/ async function getTest() {await DotNet.invokeMethodAsync(Hybrid.Maui, Test).then(res {console.log(res);}); } /scripttemplateheaderimg altVue logo classlogo src/assets/logo.svg width125 height125 /div classwrapperHelloWorld msgYou did it! /navRouterLink to/Home/RouterLinkRouterLink to/aboutAbout/RouterLink/navbutton clickgetTestTo Hybrid.Maui Test/button/div/headerRouterView / /templatestyle scoped header {line-height: 1.5;max-height: 100vh; }.logo {display: block;margin: 0 auto 2rem; }nav {width: 100%;font-size: 12px;text-align: center;margin-top: 2rem; }nav a.router-link-exact-active {color: var(--color-text); }nav a.router-link-exact-active:hover {background-color: transparent; }nav a {display: inline-block;padding: 0 1rem;border-left: 1px solid var(--color-border); }nav a:first-of-type {border: 0; }media (min-width: 1024px) {header {display: flex;place-items: center;padding-right: calc(var(--section-gap) / 2);}.logo {margin: 0 2rem 0 0;}header .wrapper {display: flex;place-items: flex-start;flex-wrap: wrap;}nav {text-align: left;margin-left: -1rem;font-size: 1rem;padding: 1rem 0;margin-top: 1rem;} } /style执行 npm run build 命令 执行 npm run build 命令发布 Vue 项目 Copy dist 将 dist 文件夹下的所有文件复制到容器项目下的 wwwroot 文件夹下 修改 index.html 内容 JS、CSS 文件名一定要与编译后的文件名一致head 中的 JS 导入添加 crossoriginanonymous 跨域支持在 body 中导入 _framework/blazor.webview.js 必须的没有它玩不成 !DOCTYPE html html langen headmeta charsetUTF-8link relicon href/favicon.icometa nameviewport contentwidthdevice-width, initial-scale1.0titleVite App/titlescript typemodule crossoriginanonymous src/assets/index-lGWBURTF.js/scriptlink relstylesheet crossorigin href/assets/index-bTbjHxa7.css /head bodydiv idappLoading.../divdiv idblazorApp/div!-- Maui 项目需要添加 autostartfalse --script src_framework/blazor.webview.js autostartfalse/script!-- Wpf 项目不需要 --script src_framework/blazor.webview.js/script /body /html效果预览 点击 To Hydrid.Wpf Test 按钮就可以在控制台打印出 C# 代码中的返回值 Demo 下载 https://github.com/Gun319/Hybrid
http://www.laogonggong.com/news/134877.html

相关文章:

  • 中微电力建设公司网站企业解决方案部
  • 网站php怎么做的江门关键词优化效果
  • 网站布局 下载wordpress icon设置
  • 最新网站网址永久发布聊城商城网站建设
  • 做网站的开发工具中国建筑装饰公司排名
  • 长安网站制作南京公司注册
  • 基因数据库网站开发价格服务器可以自己的网站吗
  • 北京市的重点门户网站有哪些网站做多大尺寸
  • 网站快速盈利电脑下什么wordpress
  • 建立网站需要哪些手续网站平面设计完成后 与客户怎样沟通
  • 怎么做网站内容马鞍山北京网站建设
  • 网站设计与建设word设计理念云南省城乡和住房建设厅网站
  • 谷城网站定制百度网站优化升上去
  • 网站吸引人的功能合肥建筑网站
  • 公共空间设计网站郑州seo网络优化公司
  • 成都网站建设优点网站是用dreamer做的_为什么后台能进去前台进不去了
  • 服装网站建设内容网站建设7个基本流程图
  • 来宾建设网站中国纪检监察
  • 建外贸网站推广网站访客qq抓取
  • 如何修改网站后台密码做企业网站还有市场吗
  • 网站建设捌金手指专业7丽泽桥网站建设
  • 网站建设者推广资源网
  • 酒店做网站搜索关键词网站
  • 桂林建设网站创世网络网站建设
  • 网站怎么赚钱的网站兼容设置
  • 企业网站建设选题的依据及意义虚拟电脑主机平台
  • 什么叫网站外链wordpress google cdn
  • 鲜花网站建设策划方案书网络营销的优势和劣势
  • 怎么仿网站链接济南logo设计制作
  • 优化网站建设哪家专业查找网站后台入口