在jsp中显示本地图片
再上传文件之前,一般我们有一个预览功能,在HTML+JS下我们可以这样处理
<script language="javascript" type="text/javascript">
function PreviewImg(imgFile)
{
//原来的预览代码,不支持 IE7。
var oldPreview = document.getElementById("oldPreview");
//oldPreview.innerHTML = "<img src=\"file:\\\\" + imgFile.value + "\" width=\"80\" height=\"60\" />";
}
</script>
<div id="newPreview"></div>
</body>
---------------------------------------
<p>请选择一个图片进行预览:<input type="file" size="20" onchange="javascript :PreviewImg(this);" /></p>
但是这样不支持IE7,在IE7下显示叉烧包!
改进代码如下:
新的预览代码,支持 IE6、IE7。
var newPreview = document.getElementById("newPreview");
newPreview.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgFile.value;
newPreview.style.width = "180px";
newPreview.style.height = "160px";
还要增加一个CSS :
<style type="text/css">
#newPreview /*这个就是预览的DIV的ID*/
{
filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);
}
</style>
这样就可以再IE6、IE7下预览本地图片了!
Microsoft.AlphaImageLoader滤镜讲解
Microsoft.AlphaImageLoader是IE滤镜的一种,其主要作用就是对图片进行透明处理。虽然FireFox和IE7以上的IE浏览器已经支持透明的PNG图片,但是就IE5-IE6而言还是有一定的意义。
语法:
filter : progid:DXImageTransform.Microsoft.AlphaImageLoader ( enabled=bEnabled , sizingMethod=sSize , src=sURL )
属性:
enabled : 可选项。布尔值(Boolean)。设置或检索滤镜是否激活。true | false true : 默认值。滤镜激活。
false : 滤镜被禁止。
sizingMethod : 可选项。字符串(String)。设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。 crop : 剪切图片以适应对象尺寸。
image : 默认值。增大或减小对象的尺寸边界以适应图片的尺寸。
scale : 缩放图片以适应对象的尺寸边界。
src : 必选项。字符串(String)。使用绝对或相对 url 地址指定背景图像。假如忽略此参数,滤镜将不会作用。
特性:
Enabled : 可读写。布尔值(Boolean)。参阅 enabled 属性。
sizingMethod : 可读写。字符串(String)。参阅 sizingMethod 属性。
src : 可读写。字符串(String)。参阅 src 属性。
说明:
在对象容器边界内,在对象的背景和内容之间显示一张图片。并提供对此图片的剪切和改变尺寸的操作。如果载入的是PNG(Portable Network Graphics)格式,则0%-100%的透明度也被提供。
PNG(Portable Network Graphics)格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG(Portable Network Graphics)格式的图片完全透明区域后面的内容。
示例:
#idDiv{position:absolute; left:140px; height:400; width:400;filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='rain1977.gif',sizingMethod='scale');}
.dream{filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='images/earglobe.gif');}
MSDN: http://msdn2.microsoft.com/en-us/library/ms532969.aspx
P.S. 当想使用backgroundimage属性时,如果不想让图片原尺寸显示,而是类似于IMG width=100% heigth=100% 的效果,可以通过此filter实现。
Example:
span.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(src='test.jpg', sizingMethod='scale')";
引用:最后说说关于FF和IE效果调和问题。这个滤镜效果只适用于IE,在FF下面无法显示,我想这是前辈说他很难实现的最终问题了。以往我们用*或者_来修复IE下和FF的区别.这一次是要找方法修复FF不能实现的问题.
其实想到的话,也很简单了.就是先让FF正常显示该图片,然后,用*或_ 来清除IE下的显示效果,最后用*或_ 来做以上的滤镜效果。大功告成!
以上是官方的说明。事实上实际操作中需要注意:AlphaImageLoader滤镜会导致该区域的链接和按钮无效,一般情况下的解决办法是为链接或按钮添加:position:relative使其相对浮动要注意的是,当加载滤镜的区域的父层有position:absolute绝对定位的时候使用position:relative也不能使链接复原。建议使用浮动办法处理。
具体操作:
为预览区域(比如要在某个 div 中预览)添加样式:filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale);。
为 AlphaImageLoader 设置 src 属性。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lsd123/archive/2008/12/29/3638329.aspx
分享到:
相关推荐
### jsp图片上传及预览知识点详解 #### 一、技术背景与应用场景 在Web开发领域,特别是电子商务网站中,用户经常会遇到上传图片的需求。例如,商家上传商品图片供买家查看,用户上传个人头像等场景。为了提高用户...
本解决方案的核心在于利用IE特有的`AlphaImageLoader`滤镜来加载本地图片资源并显示在网页上。下面将详细解释这一过程: 1. **HTML结构**: - 首先需要创建一个用于显示图片的`<div>`元素,并设置相应的样式。 - ...
它可以通过`style.filter`属性来应用,如`progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')`,但这不适用于CSS3滤镜。 解决黑圈问题的一种常见方法是使用条件注释或JavaScript检测来针对...
- **`filters.item("DXImageTransform.Microsoft.AlphaImageLoader")`**:获取到指定的AlphaImageLoader滤镜对象。 - **`src = imgFile.value`**:设置滤镜对象的源图像路径,即用户选择的文件路径。 - **`...
其中一个典型的问题就是在用户从本地选择一张图片后,图片无法立即在页面上显示出来。这种现象尤其在IE7中表现得更为明显。 #### 解决方案概述 为了解决这个问题,开发者们通常会寻找一些特定的技术或技巧来确保...
这段代码遍历所有图片元素,检测其是否为PNG格式,如果是,则创建一个新的`<span>`元素替换原图片,应用`DXImageTransform.Microsoft.AlphaImageLoader`滤镜。 ```html <!--[if IE 6]> function correctPNG() {...
-ms-filter: "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='yourimage.png', sizingMethod='scale')"; } ``` 这段代码会告诉IE6使用滤镜来加载指定的PNG24图片,并保持其透明度。 2. ...
filter: progid:DXImageTransform.Microsoft.AlphaImageLoader( enabled=bEnabled, sizingMethod=sSize, src=sURL); ``` - **`enabled`**:可选参数,布尔值。用于设置或检索滤镜是否激活,默认值为`true`。 -...
非常漂亮的Js图片边框修饰插件,并附有几种常用的示例,像阴影效果、顶部... ie解决方案: filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=‘../images/counter_bg.jpg‘, sizingMethod=‘scale
6. progid:DXImageTransform.Microsoft.BasicImage:执行基本图像操作,如旋转、缩放和翻转。 7. progid:DXImageTransform.Microsoft.Blur:模糊效果。 8. progid:DXImageTransform.Microsoft.DropShadow:添加可...
filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='image.png', sizingMethod='scale'); /* 兼容其他浏览器 */ *behavior: url(iepngfix.htc); } ``` 这里,`src`属性指定了要加载的PNG图像,`...
在JSP中实现上传图片即时显示效果功能主要涉及前端的JavaScript编程以及后端的文件处理机制。下面将详细阐述相关知识点。 ### 1. HTML与JavaScript结合实现文件上传及预览 在Web开发中,通常使用HTML的`...
3. **应用AlphaImageLoader滤镜**:对于每个符合条件的PNG图片,创建一个新的HTML `span`元素,设置其宽度、高度、样式等属性,并使用`progid:DXImageTransform.Microsoft.AlphaImageLoader`滤镜加载原PNG图片,确保...
filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='image.png', sizingMethod='scale'); ``` 这里的AlphaImageLoader滤镜会加载指定的PNG图片,并使用Alpha通道处理透明效果。 2. DD_belatedPNG库...
DXImageTransform.Microsoft.AlphaImageLoader滤镜提供了透明效果、图片的显示尺寸调整以及图片路径的指定等功能。需要注意的是,这种方法属于浏览器特定的解决方案,不能在非IE浏览器上使用。 在实现图片预览功能...
1. **CSS滤镜法**:利用CSS滤镜(filter)属性,如`progid:DXImageTransform.Microsoft.AlphaImageLoader`,可以为PNG图片添加透明支持。这种方式需要将图片作为背景图,并通过滤镜指定源图片和透明度。 ```css ....
在处理PNG透明问题时,我们主要用到的是`filter`属性中的`progid:DXImageTransform.Microsoft.AlphaImageLoader`。这个滤镜可以加载一个透明的PNG图像,并使其在IE6中显示为透明。 下面是一个示例代码: ```html ...
在代码中,还涉及到了`DXImageTransform.Microsoft.AlphaImageLoader`这个滤镜的使用,这是Internet Explorer浏览器特有的一个功能,用于在HTML元素上显示图像。通过设置`sizingMethod`属性,可以控制图像在显示时的...