科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件Asp.net日期字符串格式化显示方法

Asp.net日期字符串格式化显示方法

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在使用Asp.net的过程中,我们经常需要对时间日期进行转换,达到不同的显示效果。默认格式为:2006-6-6 14:33:34

作者:佚名 来源:论坛整理 2007年11月5日

关键字: Windows

  • 评论
  • 分享微博
  • 分享邮件
fffff 秒的小数精度为五位。其余数字被截断。

  ffffff 秒的小数精度为六位。其余数字被截断。

  fffffff 秒的小数精度为七位。其余数字被截断。

  t 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项的第一个字符(如果存在)。

  tt 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项(如果存在)。

  z 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数没有前导零。例如,太平洋标准时间是“-8”。

  zz 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数有前导零。例如,太平洋标准时间是“-08”。

  zzz 完整时区偏移量(“+”或“-”后面跟有小时和分钟)。一位数的小时数和分钟数有前导零。例如,太平洋标准时间是“-08:00”。

  : 在 TimeSeparator 中定义的默认时间分隔符。

  / 在 DateSeparator 中定义的默认日期分隔符。

  % c 其中 c 是格式模式(如果单独使用)。如果格式模式与原义字符或其他格式模式合并,则可以省略“%”字符。

  \ c 其中 c 是任意字符。照原义显示字符。若要显示反斜杠字符,请使用“\\”。

  只有上面第二个表中列出的格式模式才能用于创建自定义模式;在第一个表中列出的标准格式字符不能用于创建自定义模式。自定义模式的长度至少为两个字符;例如,

  DateTime.ToString( "d") 返回 DateTime 值;“d”是标准短日期模式。

  DateTime.ToString( "%d") 返回月中的某天;“%d”是自定义模式。

  DateTime.ToString( "d ") 返回后面跟有一个空白字符的月中的某天;“d”是自定义模式。

  比较方便的是,上面的参数可以随意组合,并且不会出错,多试试,肯定会找到你要的时间格式

  如要得到2005年06月 这样格式的时间

  可以这样写:

以下是引用片段:
date.ToString("yyyy年MM月", DateTimeFormatInfo.InvariantInfo)

  如此类推.

  下面列出一些Asp.net中具体的日期格式化用法:

  ============================================

  1.绑定时格式化日期方法:

  

以下是引用片段:
<ASP:BOUNDCOLUMN DATAFIELD= "JoinTime " DATAFORMATSTRING= "{0:yyyy-MM-dd} " > 
<ITEMSTYLE WIDTH= "18% " > </ITEMSTYLE > 
</ASP:BOUNDCOLUMN >

  2.数据控件如DataGrid/DataList等的件格式化日期方法:

以下是引用片段:
e.Item.Cell[0].Text = Convert.ToDateTime(e.Item.Cell[0].Text).ToShortDateString();

  3.用String类转换日期显示格式:

以下是引用片段:
String.Format( "yyyy-MM-dd ",yourDateTime);

  4.用Convert方法转换日期显示格式:

以下是引用片段:
Convert.ToDateTime("2005-8-23").ToString
  ("yyMMdd",System.Globalization.DateTimeFormatInfo.InvariantInfo); //支持繁体数据库

  5.直接用ToString方法转换日期显示格式:

以下是引用片段:
DateTime.Now.ToString("yyyyMMddhhmmss");
  DateTime.Now.ToString("yyyy/MM/dd hh:mm:ss")

  6.只显示年月

以下是引用片段:
DataBinder.Eval(Container.DataItem,"starttime","{0:yyyy-M}")

  7.显示时间所有部分,包括:年月日时分秒

以下是引用片段:
<asp:BoundColumn DataField="收款时间" HeaderText="收款时间" 
DataFormatString="{0:yyyy-MM-dd HH24:mm:ss}"> 
</asp:BoundColumn>

  [ASP.NET] 如何在GridView中使用DataFromatString

  在我们从业务逻辑层获得数据实体时候,接下来的事情就是要绑定到控件中。数据实体中的一些字段可以直接绑定到界面中,但是有一些字段需要重新格式化格式。比如货币单位字段,需要显示货币符号和每隔三位显示分隔符;再比如日期字段,数据库中存放的是日期和时间,但是在界面上需要按照XXXX年XX月XX日的格式显示。这时候我们就用到了DataFormatString属性。

以下是引用片段:
<asp:GridView ID="grvResult" runat="server" AutoGenerateColumns="False" Width="100%">
    <Columns>
        <asp:BoundField HeaderText="预定日期" DataField="OperationDate" DataFormatString="{0:yyyy-MM-dd}" HtmlEncode="False">
        </asp:BoundField>      
        <asp:BoundField HeaderText="订单总计" DataField="TotalRate" DataFormatString="{0:C}" HtmlEncode="False">
        </asp:BoundField>
    </Columns>
</asp:GridView>

  例如上面的代码展示了日期和货币两种绑定方式。DataFormatString中的{0}是固定的格式,这和String.Fromat(“{0}”, someString)中的{0}是一个用法,表示绑定上下文的参数索引编号。然后,在后面加入格式化字符串,具体的使用方法可以参考MSDN。

  这里需要注意以下几点

  1. 在GridView中的asp:BoundField使用DataFormatString必须设置属性HtmlEncode="False",否则不起作用。

  2. 如果需要使用日期类型的格式化字符串,必须数据实体中对应的字段也应该日起类型的。

  3. 格式化字符串C代表货币单位,需要绑定的数据类型应该是数字类型的。如果是字符串类型的不起作用,需要手动添加格式化字符串为DataFormatString="¥{0:C}"。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章