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属性文本框后面的图标按钮,弹出一个如图1所示的“选择图像”对话框,用户可以选择要显示的图像。
图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所示。
图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);
}