当前位置: 移动技术网 > IT编程>开发语言>.net > ASP.NET中Image控件使用详解

ASP.NET中Image控件使用详解

2017年12月12日  | 移动技术网IT编程  | 我要评论

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" "">
<html xmlns="" >
<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);
}

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网