{"id":17038,"date":"2023-02-26T15:59:07","date_gmt":"2023-02-26T07:59:07","guid":{"rendered":"https:\/\/www.zhidianwl.net\/zhidianwl\/2023\/02\/26\/blazor%e9%a1%b9%e7%9b%ae%e6%89%93%e5%8c%85%e4%b8%ba%e5%ae%89%e5%8d%93apk%e6%96%b9%e6%b3%95%e4%bb%8b%e7%bb%8d\/"},"modified":"2023-02-26T15:59:07","modified_gmt":"2023-02-26T07:59:07","slug":"blazor%e9%a1%b9%e7%9b%ae%e6%89%93%e5%8c%85%e4%b8%ba%e5%ae%89%e5%8d%93apk%e6%96%b9%e6%b3%95%e4%bb%8b%e7%bb%8d","status":"publish","type":"post","link":"https:\/\/www.zhidianwl.net\/zhidianwl\/2023\/02\/26\/blazor%e9%a1%b9%e7%9b%ae%e6%89%93%e5%8c%85%e4%b8%ba%e5%ae%89%e5%8d%93apk%e6%96%b9%e6%b3%95%e4%bb%8b%e7%bb%8d\/","title":{"rendered":"blazor\u9879\u76ee\u6253\u5305\u4e3a\u5b89\u5353apk\u65b9\u6cd5\u4ecb\u7ecd"},"content":{"rendered":"

Blazor\u662f\u4e00\u4e2a\u7531\u5fae\u8f6f\u63a8\u51fa\u7684Web\u5e94\u7528\u7a0b\u5e8f\u6846\u67b6\uff0c\u5b83\u4f7f\u7528C#\u548c.NET\u8fd0\u884c\u65f6\uff0c\u53ef\u4ee5\u5728\u6d4f\u89c8\u5668\u4e2d\u6784\u5efa\u4ea4\u4e92\u5f0f\u7684Web\u7528\u6237\u754c\u9762\u3002\u968f\u7740\u79fb\u52a8\u8bbe\u5907\u7684\u666e\u53ca\uff0c\u8d8a\u6765\u8d8a\u591a\u7684\u7528\u6237\u5e0c\u671b\u5728\u79fb\u52a8\u8bbe\u5907\u4e0a\u8bbf\u95eeWeb\u5e94\u7528\u7a0b\u5e8f\u3002\u56e0\u6b64\uff0c\u5c06Blazor\u9879\u76ee\u6253\u5305\u4e3a\u5b89\u5353apk\u5df2\u7ecf\u6210\u4e3a\u4e86\u4e00\u4e2a\u70ed\u95e8\u8bdd\u9898\u3002\u4e0b\u9762\u6211\u4eec\u6765\u4ecb\u7ecd\u4e00\u4e0b\u5982\u4f55\u5c06Blazor\u9879\u76ee\u6253\u5305\u4e3a\u5b89\u5353apk\u3002<\/p>\n

1. \u5b89\u88c5.NET SDK\u548cBlazor WebAssembly<\/p>\n

\u5728\u5f00\u59cb\u4e4b\u524d\uff0c\u60a8\u9700\u8981\u5b89\u88c5.NET SDK\u548cBlazor WebAssembly\u3002\u60a8\u53ef\u4ee5\u4ece\u5fae\u8f6f\u5b98\u7f51\u4e0b\u8f7d\u6700\u65b0\u7248\u672c\u7684.NET SDK\u548cBlazor WebAssembly\uff0c\u5e76\u6309\u7167\u5b98\u65b9\u6307\u5357\u8fdb\u884c\u5b89\u88c5\u3002<\/p>\n

2. \u521b\u5efaBlazor WebAssembly\u9879\u76ee<\/p>\n

\u5728Visual Studio\u4e2d\u521b\u5efa\u4e00\u4e2a\u65b0\u7684Blazor WebAssembly\u9879\u76ee\u3002\u5728\u521b\u5efa\u9879\u76ee\u65f6\uff0c\u9009\u62e9\u201cBlazor WebAssembly App\u201d\u6a21\u677f\uff0c\u5e76\u9009\u62e9\u201cASP.NET Core Hosted\u201d\u4f5c\u4e3a\u4e3b\u673a\u7c7b\u578b\u3002<\/p>\n

3. \u5728\u9879\u76ee\u4e2d\u6dfb\u52a0Android\u5e73\u53f0\u652f\u6301<\/p>\n

\u5728\u9879\u76ee\u4e2d\u6dfb\u52a0Android\u5e73\u53f0\u652f\u6301\uff0c\u9700\u8981\u4f7f\u7528Blazor WebAssembly\u7684\u5b98\u65b9\u63d2\u4ef6\u201cBlazor WebAssembly Android\u201d\u3002\u60a8\u53ef\u4ee5\u4f7f\u7528Visual Studio\u7684NuGet\u5305\u7ba1\u7406\u5668\u6765\u5b89\u88c5\u6b64\u63d2\u4ef6\u3002\u5728NuGet\u5305\u7ba1\u7406\u5668\u4e2d\u641c\u7d22\u201cBlazor WebAssembly Android\u201d\u5e76\u5b89\u88c5\u3002<\/p>\n

4. \u914d\u7f6e\u9879\u76ee<\/p>\n

\u5728\u9879\u76ee\u4e2d\u6dfb\u52a0Android\u5e73\u53f0\u652f\u6301\u540e\uff0c\u9700\u8981\u914d\u7f6e\u9879\u76ee\u4ee5\u652f\u6301Android\u5e73\u53f0\u3002\u5728\u9879\u76ee\u7684\u6839\u76ee\u5f55\u4e0b\u521b\u5efa\u4e00\u4e2a\u540d\u4e3a\u201cAndroid\u201d\u7684\u6587\u4ef6\u5939\uff0c\u5e76\u5728\u5176\u4e2d\u521b\u5efa\u4e00\u4e2a\u540d\u4e3a\u201cMainActivity.cs\u201d\u7684\u6587\u4ef6\u3002<\/p>\n

\u5728MainActivity.cs\u6587\u4ef6\u4e2d\uff0c\u6dfb\u52a0\u4ee5\u4e0b\u4ee3\u7801\uff1a<\/p>\n

“`<\/p>\n

using Android.App;<\/p>\n

using Android.Content.PM;<\/p>\n

using Android.OS;<\/p>\n

ustopvpn\u96c6\u6210<\/a>ing Android.Runtime;<\/p>\n

using Android.Views;<\/p>\n

using Android.Widget;<\/p>\n

using Microsoft.AspNetCore.Components.WebView.Maui;<\/p>\n

namespace BlazorApp.Android<\/p>\n

{<\/p>\n

[Activity(Label = “BlazorApp”, Theme = “@style\/MainTheme”, MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation)]<\/p>\n

public class MainActivity : MauiAppCompatActivity<\/p>\n

{<\/p>\n

protected override void OnCreate(Bundle savedInstanceState)<\/p>\n

{<\/p>\n

base.OnCreate(savedInstanceState);<\/p>\n

\/\/ Set our view from the “main” layout resource<\/p>\n

SetContentView(Resource.Layout.activity_main);<\/p>\n

\/\/ Initialize the Blazor WebView<\/p>\n

var webView = FindViewById(“blazorWebView”);<\/p>\n

webView.RootComponents.Add(“app”);<\/p>\n

}<\/p>\n

}<\/p>\n

}<\/p>\n

“`<\/p>\n

\u8fd9\u6bb5\u4ee3\u7801\u5c06\u521d\u59cb\u5316Blazor WebView\uff0c\u5e76\u5c06App\u7ec4\u4ef6\u6dfb\u52a0\u5230WebView\u4e2d\u3002<\/p>\n

<\/figure>\n<\/p>\n

5. \u6253\u5305\u9879\u76ee\u4e3a\u5b89\u5353apk<\/p>\n

\u5b8c\u6210\u4e0a\u8ff0\u6b65\u9aa4\u540e\uff0c\u60a8\u53ef\u4ee5\u4f7f\u7528Visual Studio\u7684Android\u6253\u5305\u5de5\u5177\u5c06Blaapp\u8f6f\u4ef6\u5f00\u53d1<\/a>zor\u9879\u76ee\u6253\u5305\u4e3a\u5b89\u5353apk\u3002\u5728Visual Studio\u4e2d\u6253\u5f00\u9879\u76ee\uff0c\u9009\u62e9\u201c\u751f\u6210\u201d\u83dc\u5355\uff0c\u7136\u540e\u9009\u62e9\u201c\u751f\u6210\u89e3\u51b3\u65b9\u6848\u201d\u9009\u9879\u3002\u5728\u751f\u6210\u89e3\u51b3\u65b9\u6848\u540e\uff0c\u60a8\u5c06\u5728\u9879\u76ee\u7684\u201cbin\\Debug\\net5.0-android\u201d\u6587\u4ef6\u5939\u4e2d\u627e\u5230\u751f\u6210\u7684apk\u6587\u4ef6\u3002<\/p>\n

\u603b\u7ed3<\/p>\n

\u5c06Blazor\u9879\u76ee\u6253\u5305\u4e3a\u5b89\u5353apk\u5e76\u4e0d\u96be\uff0c\u53ea\u9700\u8981\u6309\u7167\u4e0a\u8ff0\u6b65\u9aa4\u8fdb\u884c\u64cd\u4f5c\u5373\u53ef\u3002\u9700\u8981\u6ce8\u610f\u7684\u662f\uff0cBlazor WebAssembly Android\u63d2\u4ef6\u76ee\u524d\u8fd8\u5904\u4e8e\u9884\u89c8\u9636\u6bb5\uff0c\u53ef\u80fd\u5b58\u5728\u4e00\u4e9b\u95ee\u9898\u3002\u5982\u679c\u60a8\u5728\u4f7f\u7528\u4e2d\u9047\u5230\u4e86\u95ee\u9898\uff0c\u53ef\u4ee5\u53c2\u8003\u5b98\u65b9\u6587\u6863\u6216\u5728\u793e\u533a\u4e2d\u5bfb\u6c42\u5e2e\u52a9\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"

Blazor\u662f\u4e00\u4e2a\u7531\u5fae\u8f6f\u63a8\u51fa\u7684Web\u5e94\u7528\u7a0b\u5e8f\u6846\u67b6\uff0c\u5b83\u4f7f\u7528C#\u548c.NET\u8fd0\u884c\u65f6\uff0c\u53ef\u4ee5\u5728\u6d4f\u89c8\u5668\u4e2d\u6784\u5efa\u4ea4\u4e92\u5f0f\u7684Web\u7528\u6237\u754c\u9762\u3002\u968f\u7740\u79fb\u52a8\u8bbe\u5907\u7684\u666e\u53ca\uff0c\u8d8a\u6765\u8d8a\u591a\u7684\u7528\u6237\u5e0c\u671b\u5728\u79fb\u52a8\u8bbe\u5907\u4e0a\u8bbf\u95eeWeb\u5e94\u7528\u7a0b\u5e8f\u3002\u56e0\u6b64\uff0c\u5c06<\/p>\n","protected":false},"author":23,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[12099,7444,245,581,588],"topic":[],"class_list":["post-17038","post","type-post","status-publish","format-standard","hentry","category-kaifaapp","tag-ios","tag-7444","tag-245","tag-581","tag-588"],"_links":{"self":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts\/17038","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/users\/23"}],"replies":[{"embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/comments?post=17038"}],"version-history":[{"count":0,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/posts\/17038\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/media?parent=17038"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/categories?post=17038"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/tags?post=17038"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.zhidianwl.net\/zhidianwl\/wp-json\/wp\/v2\/topic?post=17038"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}