Extensions in UWP Community Toolkit - WebViewExtensions

来源:https://www.cnblogs.com/shaomeng/archive/2018/04/13/8744628.html
-Advertisement-
Play Games

概述 UWP Community Toolkit Extensions 中有一個為 WebView 提供的擴展 - WebViewExtensions,本篇我們結合代碼詳細講解 WebView Extensions 的實現。 WebView Extensions 允許使用附加屬性,在 XAML 中指 ...


概述

UWP Community Toolkit Extensions 中有一個為 WebView 提供的擴展 - WebViewExtensions,本篇我們結合代碼詳細講解 WebView Extensions 的實現。

WebView Extensions 允許使用附加屬性,在 XAML 中指定 WebView 的目標地址或目標網頁內容,關於這一擴展,官方示例應用中並沒有對應示例,我們實現一個簡單的示例截圖:

Source: https://github.com/Microsoft/UWPCommunityToolkit/tree/master/Microsoft.Toolkit.Uwp.UI/Extensions/WebView

Doc: https://docs.microsoft.com/zh-cn/windows/uwpcommunitytoolkit/extensions/webviewextensions

Namespace: Microsoft.Toolkit.Uwp.UI.Extensions; Nuget: Microsoft.Toolkit.Uwp.UI;

 

開發過程

代碼分析

我們先來看一下 WebViewExtensions 的類結構:

其中 Webview.cs 和 WebView.Properties.cs 類已被標記為 Obsolete,被 WebViewExtensions.cs 替代。

WebViewExtensions.cs

首先來看類中定義的幾個附加屬性:

  • Content - WebView 的目標網頁內容,類型為 string,變化時觸發 OnContentChanged 事件;
  • ContentUri - WebView 的目標網頁地址,類型為 Uri,變化時觸發 OnContentUriChanged 事件;

接下來看看這兩個事件的處理邏輯:

1. OnContentChanged(d, e)

這個方法很簡單,就是讀取變化後的 string,使用 WebView 的 NavigateToString 方法賦值;需要註意的是,這裡的 content 並不一定是一個有效的 html 網頁,也可以是一段普通的字元串,Webview 也會以預設的字體樣式來顯示這段字元串;

private static void OnContentChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
    Windows.UI.Xaml.Controls.WebView wv = d as Windows.UI.Xaml.Controls.WebView;

    var content = e.NewValue as string;

    if (string.IsNullOrEmpty(content))
    {
        return;
    }

    wv?.NavigateToString(content);
}

2. OnContentUriChanged(d, e)

這個方法的實現也很簡單,讀取並把內容轉為 Uri 類型,如果有效則跳轉到對應的 Uri 網站;這裡要求傳入的值一定是格式正確的網址,雖然不一定是可用的網址,不然會造成 crash;

private static void OnContentUriChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
    Windows.UI.Xaml.Controls.WebView wv = d as Windows.UI.Xaml.Controls.WebView;

    var uri = e.NewValue as Uri;

    if (uri == null)
    {
        return;
    }

    wv?.Navigate(uri);
}

 

調用示例

我們讓 Webview 綁定 TextBlock 的 Text 作為 ContentUri,可以看到 WebView 正確跳轉到了指定網址;

<TextBlock Text="http://www.cnblogs.com/shaomeng/" x:Name="uri"/>
<WebView Grid.Row="1" extensions:WebView.ContentUri="{Binding Text, ElementName=uri}"/>

 

總結

到這裡我們就把 UWP Community Toolkit Extensions 中的 WebViewExtensions 的源代碼實現過程和簡單的調用示例講解完成了,希望能對大家更好的理解和使用這個擴展有所幫助。歡迎大家多多交流,謝謝!

最後,再跟大家安利一下 UWPCommunityToolkit 的官方微博:https://weibo.com/u/6506046490大家可以通過微博關註最新動態。

衷心感謝 UWPCommunityToolkit 的作者們傑出的工作,Thank you so much, UWPCommunityToolkit authors!!!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天,mysql突然無法啟動了。 解決辦法記錄一下: 1.刪除data文件 我的:C:\Program Files\MySQL\MySQL Server 5.7\data 註意:這個文件可能在你一直試圖操作之後,出現被占用,無法刪除的情況,還找不到到底誰占用了。 可以嘗試重啟電腦。 2.dos下, ...
  • 一、簡介 作為集成學習中非常著名的方法,隨機森林被譽為“代表集成學習技術水平的方法”,由於其簡單、容易實現、計算開銷小,使得它在現實任務中得到廣泛使用,因為其來源於決策樹和bagging,決策樹我在前面的一篇博客中已經詳細介紹,下麵就來簡單介紹一下集成學習與Bagging; 二、集成學習 集成學習( ...
  • 實現功能: 1.將基本數據類型,如int, long, double, 及String類型數據寫入到 byte[]中, 2.從 byte[]中將數據讀取到 int, long, double, 及String類型變數中 運行結果: ...
  • 實現功能: 1.將基本數據類型,如int, long, double, 及String類型數據寫入到文件中, 2.從文件中將數據讀取到 int, long, double, 及String類型變數中 運行結果: ...
  • 1. 操作系統介面 os 模塊提供很多函數與操作系統進行交互︰ 確保使用import os而不是from os import *。這樣可以防止函數os.open()覆蓋內建函數open(),兩者之間的操作是很不同的。內建函數dir()和help()對os這樣的大型模塊提供互動式的幫助是很有用的: 對 ...
  • 前言 在這裡主要分析下ThreadLocal類的結構,與set(),get(),remove()方法的源碼 1.ThreadLocal類的結構 ThreadLocal是java.lang下麵的類。 這個類下麵有幾個靜態內部類。比如: 在ThreadLocalMap類下麵還有一個靜態內部類 在上圖中可 ...
  • sqlalchemy中使用query查詢,而flask-sqlalchemy中使用basequery查詢,他們是子類與父類的關係 假設 page_index=1,page_size=10;所有分頁查詢不可以再跟first(),all()等 1.用offset()設置索引偏移量,limit()限制取出 ...
  • web api與webservice以及wcf的區別? Web Service 1、它是基於SOAP協議的,數據格式是XML 2、只支持HTTP協議 3、它不是開源的,但可以被任意一個瞭解XML的人使用 4、它只能部署在IIS上 WCF 1、這個也是基於SOAP的,數據格式是XML 2、這個是Web ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...