欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.NET中Image控件使用详解

程序员文章站 2023-12-16 10:31:46
image控件又称图像控件,主要用来显示用户的图片或图像信息。 一、属性 表1 image控件常用属性及说明 属性...

image控件又称图像控件,主要用来显示用户的图片或图像信息。

一、属性

表1 image控件常用属性及说明

属性 说明
id 控件id
imagealign 获取或设置image控件相对于网页上其他元素的对齐方式
imageurl 获取或设置在image控件中显示的图像的位置
width 控件的宽度
visible 控件是否可见
cssclass 控件呈现的样式
backcolor 控件的背景颜色
enabled 控件是否可用

image控件的大部分属性和label控件类似,在此主要讲解一下其imageurl属性设置。

imageurl属性用来获取image控件中要显示图像的地址,在设置该属性时,单击imageurl属性文本框后面的ASP.NET中Image控件使用详解图标按钮,弹出一个如图1所示的“选择图像”对话框,用户可以选择要显示的图像。

ASP.NET中Image控件使用详解

图1  “选择图像”对话框

二、方法

image控件常用方法同label控件类似,具体请参见label控件常用方法。这里主要介绍一下该控件的resolveurl方法,resolveurl方法主要用来将url转换为在请求客户端可用的url。

例如,要使用resolveurl方法设置一个image控件的链接图像路径,可以编写如下代码。

复制代码 代码如下:

image1.imageurl = resolveurl(~/image/image1.gif);

三、事件

image控件常用事件同label控件类似,具体请参见label控件常用事件。

四、示例

示例:

image控件示例

下面示例主要通过设置image控件的imageurl属性在该控件上显示链接图片。新建一个网站,默认主页为default.aspx,在default.aspx页面上添加一个image控件,其属性设置如表2所示。

表2 image控件属性设置

属性名称 属性值
id imageurl
imageurl ~/image/image1.gif(链接图片)
imagealign middle(居中对齐)

执行程序,示例运行结果如图2所示。

ASP.NET中Image控件使用详解

图2  image控件示例

程序完整代码如下:

default.aspx.cs代码文件

复制代码 代码如下:

using system;
using system.data;
using system.configuration;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
 
public partial class _default : system.web.ui.page
{
    protected void page_load(object sender, eventargs e)
    {
 
    }
}

default.aspx 设计文件

复制代码 代码如下:

<%@ page language="c#" autoeventwireup="true"  codefile="default.aspx.cs" inherits="_default" %>
<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title>image控件示例</title>
</head>
<body>
 
    <form id="form1" runat="server">
    <div>
        <asp:image id="image1" runat="server" height="177px" imagealign="middle"
             imageurl="~/image/image1.gif" width="121px" />
    </div>
    </form>
 
</body>
</html>

五、扩展

image控件当没有图片时,显示"红色的x" 不够友好,可以设置其alternatetext属性,也可以显示指定的图片

1.普通显示

复制代码 代码如下:

string str ="~/img/"+int.parse(textbox1.text)+".gif";
 
if (!file.exists(server.mappath(str)))//不存在时显示nophoto.gif
{
    image1.imageurl = "~/img/nophoto.gif";
    //response.write("bucunzai");
}
else//有的时候显示
{
    image1.imageurl = str;
    //response.write("cunzai");
}

2.还有一种可能是从数据库中读取二进制的图片时(红色部分需要从数据库中读取)

复制代码 代码如下:

byte [] b=....;//从数据库中读取
 
if (b == null || b.length == 0)
{
    //当没有图片数据时显示默认的图片nophoto.gif
    filestream fs = new filestream(server.mappath("~/management/images/nophoto.gif"), filemode.open, fileaccess.read);
    byte[] mydata = new byte[fs.length];
    int length = convert.toint32(fs.length);
    fs.read(mydata, 0, length);
    fs.close();
    this.response.outputstream.write(mydata, 0, length);
    this.response.end();
}
else
{
    response.contenttype = ...;//从数据库中读取图片的后缀名
    response.outputstream.write(b, 0, b.length);
}

相关标签: ASP.NET Image

上一篇:

下一篇: