UWP ListView添加分割線

来源:http://www.cnblogs.com/xiaocaidev/archive/2017/06/13/6995743.html
-Advertisement-
Play Games

先看效果: 我並沒有找到有設置ListView分割線的屬性 下麵是一個比較簡單的實現,如果有同學有更好的實現,歡迎留言,讓我們共同進步。我的敘述不一定准確 實現的方法就是在DataTemplate里包一個Border 1、首先自定義一個UserControl來實現佈局,文件名為ItemView.xa ...


先看效果:

我並沒有找到有設置ListView分割線的屬性

下麵是一個比較簡單的實現,如果有同學有更好的實現,歡迎留言,讓我們共同進步。我的敘述不一定准確

實現的方法就是在DataTemplate里包一個Border

 1、首先自定義一個UserControl來實現佈局,文件名為ItemView.xaml,代碼如下

xaml代碼

 1 <UserControl
 2     x:Class="Demo.UWP.ItemViews.NewsItemView"
 3     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 4     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 5     xmlns:controls="using:Microsoft.Toolkit.Uwp.UI.Controls"
 6     xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
 7     xmlns:local="using:Demo.UWP.ItemViews"
 8     xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
 9     d:DesignHeight="300"
10     d:DesignWidth="400"
11     mc:Ignorable="d">
12     <Border BorderBrush="#e3e3e3" BorderThickness="0,0.5,0,0">
13         <Grid>
14             <Grid.ColumnDefinitions>
15                 <ColumnDefinition Width="Auto" />
16                 <ColumnDefinition Width="*" />
17             </Grid.ColumnDefinitions>
18             <Grid.RowDefinitions>
19                 <RowDefinition Height="Auto" />
20             </Grid.RowDefinitions>
21             <controls:ImageEx
22                 Grid.Column="0"
23                 Width="88"
24                 Height="66"
25                 Margin="10"
26                 HorizontalAlignment="Center"
27                 VerticalAlignment="Center"
28                 IsCacheEnabled="True"
29                 PlaceholderSource="{x:Bind News.PlaceholderSource}"
30                 PlaceholderStretch="UniformToFill"
31                 Source="{x:Bind News.ImgUrl}"
32                 Stretch="UniformToFill" />
33 
34             <Grid
35                 Grid.Row="0"
36                 Grid.Column="1"
37                 Margin="0,0,10,5">
38                 <Grid.ColumnDefinitions>
39                     <ColumnDefinition Width="*" />
40                 </Grid.ColumnDefinitions>
41                 <Grid.RowDefinitions>
42                     <RowDefinition Height="Auto" />
43                     <RowDefinition Height="Auto" />
44                     <RowDefinition Height="Auto" />
45                 </Grid.RowDefinitions>
46                 <TextBlock
47                     Grid.Row="0"
48                     Grid.Column="0"
49                     Margin="0,5,0,0"
50                     FontSize="14"
51                     Foreground="Black"
52                     Text="{x:Bind News.Title}"
53                     TextWrapping="Wrap" />
54                 <TextBlock
55                     Grid.Row="1"
56                     Grid.Column="0"
57                     Margin="0,0,0,0"
58                     FontSize="12"
59                     Foreground="LightGray"
60                     Text="{x:Bind News.SubTitle}"
61                     TextWrapping="Wrap" />
62                 <TextBlock
63                     Grid.Row="2"
64                     Grid.Column="0"
65                     Margin="0,0,0,0"
66                     FontSize="12"
67                     Foreground="Red"
68                     Text="{x:Bind News.Price}"
69                     TextWrapping="Wrap" />
70             </Grid>
71         </Grid>
72     </Border>
73 </UserControl>
View Code

 

cs代碼

 1 using Demo.UWP.Models;
 2 using System;
 3 using System.Collections.Generic;
 4 using System.IO;
 5 using System.Linq;
 6 using System.Runtime.InteropServices.WindowsRuntime;
 7 using Windows.Foundation;
 8 using Windows.Foundation.Collections;
 9 using Windows.UI.Xaml;
10 using Windows.UI.Xaml.Controls;
11 using Windows.UI.Xaml.Controls.Primitives;
12 using Windows.UI.Xaml.Data;
13 using Windows.UI.Xaml.Input;
14 using Windows.UI.Xaml.Media;
15 using Windows.UI.Xaml.Navigation;
16 
17 // The User Control item template is documented at https://go.microsoft.com/fwlink/?LinkId=234236
18 
19 namespace Demo.UWP.ItemViews
20 {
21     public sealed partial class NewsItemView : UserControl
22     {
23         public NewsBean News => this.DataContext as NewsBean;
24         public NewsItemView()
25         {
26             this.InitializeComponent();
27             this.DataContextChanged += (s, e) => Bindings.Update();
28         }
29     }
30 }
View Code

 

這裡用到了x:Bind,需要知道綁定數據的類型,將DataContext轉換為NewsBean對象,(=>其實就是定義屬性的簡寫)

2、定義一個ListView

 1     <Page.Resources>
 2         <ResourceDictionary>
 3             <DataTemplate x:Key="NewsTemplate">
 4                 <local:NewsItemView />
 5             </DataTemplate>
 6         </ResourceDictionary>
 7     </Page.Resources>
 8     <ListView
 9         IsItemClickEnabled="True"
10         ItemContainerStyle="{StaticResource ListViewItemStyle1}"
11         ItemTemplate="{StaticResource NewsTemplate}"
12         ItemsSource="{x:Bind NewsList}"
13         SelectionMode="None" />

ViewModel

 1 public ObservableCollection<ItemData> NewsList { get; set; }
 2 
 3         public HomeViewModel()
 4         {
 5             NewsList = new ObservableCollection<ItemData>
 6             {
 7                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
 8                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用,建議6-7人使用,建議6-7人使用", Price = "¥328", ItemType = 2},
 9                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
10                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
11                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
12                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
13                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
14                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2},
15                 new NewsBean() {Title = "東北小廚", SubTitle = "[豐莊]午市套餐C,建議6-7人使用", Price = "¥328", ItemType = 2}
16             };
17 
18         }

 

3、發現了一個問題,分割線沒有撐滿,怎麼辦呢?

更改ItemContainerStyle

<Style x:Key="ListViewItemStyle1" TargetType="ListViewItem"
<!--去除預設邊距-->
   <Setter Property="Padding" Value="0" /> <!--讓寬度撐滿--> <Setter Property="HorizontalContentAlignment" Value="Stretch" /> </Style>

  

 轉載請標明出處:http://www.cnblogs.com/xiaocaidev/p/6995743.html,本文出自:【xiaocaidev的博客

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、初步瞭解HTML HTML是一種超文本標簽語言,瀏覽器則是用來“解釋和執行”HTML源碼的工具。 HTML的基本結構 其中<!DOCTYPE html>是文檔類型聲明,聲明這個文件必須是HTML5文件,讓瀏覽器按照HTML5準備進行解析,必須在HTML5中,必須要有,且是一定要寫在文件的最上方滴 ...
  • 上一篇我們講到angular對於timepicker的一個封裝後的插件,但是由於angular的版本必須是v1.2.30以上的。對於有些大型系統,一時升級angular的版本實在耗費時間。那麼可以用這種方法來取值。 頁面上的時間格式是這樣的: 文件引入 html js: ...
  • 筆者菜鳥里最不會飛的那個,所以這些基礎的習慣都沒養成,正好抽時間特意做個筆記以方便自己規範代碼, 有興趣的大佬多多指點. 養成好的編碼習慣收益良多, 總結下編碼時應註意的細節《借鑒高程里代碼約束》,對了默默吐槽下,說是前端不需要英語基礎的那些機構們真的是為了錢失了智; a .命名約束:匈牙利命名/駝 ...
  • IE每個版本判斷 <script type="text/javascript"> var isIE = function(ver){ var b = document.createElement('b'); b.innerHTML = '<!--[if IE '+ ver +']><i></i><! ...
  • 把以上兩個文件放到同一目錄 運行index.html文件就可以看到效果了。 如果出現 : TypeError: Cannot set property '$render' of undefined 說明angular的版本太低,這個版本要求至少在v1.2.30以上. github傳送門:https: ...
  • 本人做前端兩年,感覺沒什麼進步,自己還是太菜了,想通過博客來記錄一下自己學習進度,以便日後自己查看和想學習Vue的朋友參考,大家互相學習,有寫得不對的地方歡迎大家指點,助我成長成大神,哈哈!!! ...
  • (1)全局環境 在全局環境使用this,它指的就是頂層對象window。 (2)構造函數 構造函數中的this,指的是實例對象。 (3)對象的方法 當A對象的方法被賦予B對象,該方法中的this就從指向A對象變成了指向B對象。所以要特別小心,將某個對象的方法賦值給另一個對象,會改變this的指向。 ...
  • 一,工程圖。 二,代碼。 RootViewController.m #import "RootViewController.h" //加入頭文件 #import "UIImageView+WebCache.h" @interface RootViewController () @end @imple ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...