Archive

Archive for the ‘Web’ Category

CSS Background-Position: left right center top buttom属性的解释

May 16th, 2012 Tony hu No comments

1.background-position:left top;

背景图片的左上角和容器(container)的左上角对齐,超出的部分隐藏。

等同于 background-position:0,0;

也等同于background-position:0%,0%;

2.background-position:right bottom;

背景图片的右下角和容器(container)的右下角对齐,超出的部分隐藏。

等同于background-positon:100%,100%;

也等同于background-positon:容器(container)的宽度-背景图片的宽度,容器(container)的高度-背景图片的高度

3.background-position:500px 15px;

背景图片从容器(container)左上角的地方向右移500px,向下移15px,超出的部分隐藏。

4.background-position:-500px -15px;

背景图片从容器(container)左上角的地方向左移500px,向上移15px,超出的部分隐藏。

5.background-position:50% 50%;这句经常让新手出错!

等同于left:{容器(container)的宽度—背景图片的宽度}*left百分比,超出的部分隐藏。

等同于right:{容器(container)的高度—背景图片的高度}*right百分比,超出的部分隐藏。

例如:background-position:50% 50%;就是background-position:(1000-2000)*50%px,(500-30)*50%px;即background- position:-500px,235px;也就是背景图片从容器(container)的左上角向左移500px,向下移235px;

6.(这种情况背景图片应该用bg2.jpg才能看出效果,bg.jpg的高度太小效果不明显)

background-position:-50% -50%;

等同于left:-{{容器(container)的宽度—背景图片的宽度}*left百分比(百分比都取正值)},超出的部分隐藏。

等同于right:-{{容器(container)的高度—背景图片的高度}*right百分比(百分比都取正值)},超出的部分隐藏。

例如:background-position:-50% -50%;就是background-position:-{(1000-500)*50%}px,-{(500-360)*50%}px;即 background- position:-250px,-70px;也就是背景图片从容器(container)的左上角向左移250px,向上移70px;

—————————————————

之前一直没有理解,今天终于搞明白了,强大的CSS啊。

转自 http://blog.csdn.net/yja886/article/details/7171135

Categories: Css Tags:

Asp.net中MasterPage的使用

June 4th, 2011 Tony hu No comments

1. 创建 MasterPage,后缀名 .master, 如 x.master.
其中用 <asp:ContentPlaceHolder /> 定义空位。如:

<asp:ContentPlaceHolder ID=”ContentPlaceHolder1″ Runat=”Server”>
</asp:ContentPlaceHolder>
2. 创建内容页面。
在 NewItem 对话框里选择 “select master page”, 选择上一步创建的 MasterPage.
产生的代码里, MasterPageFile 属性指定了 MasterPage 的位置:

<%@ Page Language=”VB” MasterPageFile=”~/x.master” Title=”无标题页面” %>

页面里用 <asp:Content /> 来添加内容到对应的空位:

<asp:Content ID=”Content1″ ContentPlaceHolderId=”ContentPlaceHolder1″ Runat=”Server”>
内容
</asp:Content/>

内容页面没有 <form id=”form1″ runat=”server”>
3. 利用 MasterPage 可以使用多种语言来编写一个页面的各个部分。
4. 除了在 <%@ Page %> 里面指定 MasterPage, 也可以在 web.config 指定:

<configuration>
<system.web>
<pages masterPageFile=”~/x.master” />
</system.web>
</configuration>

这样定义后,如果创建 Page 时选择了 master page, 则在 <%@ Page %> 里面不需要指定即可使用该 MasterPage.
其他页面要使用不同的 MasterPage 的话,只要用第一种方法在 Page directive 里面明确的覆盖 web.config 里的设置即可。

可以仅对一组 pages 指定 MasterPage. 下例利用 web.config 的 location 元素,设定了 Admin 目录下的页面采用的不同的 MasterPage.

<configuration>
<location path=”Admin”>
<system.web>
<pages masterPageFile=”~/y.master” />
</system.web>
</location>
</configuration>
5. 在内容页面如何设定 Page 的 Title ?

默认情况下,Title 在 MasterPage 中指定后,其他具体页面就都使用这个 Title.
在具体页面,可以有两个办法修改 Title:

a. <%@ Page Title=”test” %>

b. 代码中:

protected void Page_LoadComplete(object sender, EventArgs e)
{
Master.Page.Title = “Hello”;
}
6. 访问 MasterPage 中的属性和控件。

用 Master 属性来访问。

a. 假设 MasterPage 中有一个 Label1, 那么在内容页面可以这样:

protected void Page_LoadComplete(object sender, EventArgs e)
{
string text = (Master.FindControl(“Label1″) as Label).Text;
}

页面加载的次序:

要获取在 MasterPage 的 Page_Load 里面设定的值,必须在内容页面的 Page_LoadComplete 中来写。

前面提到的 FindControl() 方法来查找 MasterPage 中的控件,是一种后期绑定的做法,一般是不安全的。因为这取决于 MasterPage 中是否存在这个 tag,如果被删除了,则会导致错误。
比较好的做法是,在 MasterPage 中用属性封装对他的控件的访问;如果用 FindControl(), 则总是检查其结果是否为 null.
7. 指定 MasterPage 中的默认内容

直接在 <asp:ControlPlaceHolder /> 标签之间指定即可。
如果子页面不重新指定,则会采用该默认内容。
8. 编程的方式指定 Master Page

protected void Page_PreInit(object sender, EventArgs e)
{
Page.MasterPageFile = “~/x.master”;
}
9. 嵌套的 Master Page

Master Page 可以继承自更高层次的 Master Page. 但是在 VS2005 中创建这种子 Master Page 的时候,不会有默认的支持。
假设有了一个 A.master,
我们现在先创建一个普通的 B.master,
然后删除其中除了 Page directive 的其他部分。
把 Page Directive 修改为如下,并加入自己要定义的 PlaceHolder:

<%@ Master MasterPageFile=”~/A.master” %>

<asp:Content ID=”Content1″ ContentPlaceHolderID=”ContentPlaceHolder1″ Runat=”server”>
Hello!
<asp:ContentPlaceHolder ID=”ContentPlaceHolder2″ Runat=”server”>
</asp:ContentPlaceHolder>
</asp:Content>

用嵌套的模板产生的子页面将不能采用 VS2005 的 design 模式。
10. 容器特定的 Master Pages

为了能兼容不同的浏览器,asp.net 2.0 支持多个 Master Page. 在运行时将自动加载合适的 Master Page.

语法如下:

<%@ Page Language=”VB” MasterPageFile=”~/Abc.master”
Mozilla:MasterPageFile=”~/AbcMozilla.master”
Opera:MasterPageFile=”~/AbcMozilla.master” %>
11. 页面请求的次序

当用户请求一个用 Master Page 构建的页面时,各种事件发生的次序如下:

Master Page 子控件初始化;
内容页面子控件初始化;
Master Page 初始化;
内容页面初始化;
内容页面 Page_Load;
Master Page 的 Page_Load;
Master Page 子控件加载;
内容页面子控件加载;
注意点:

因为内容页面的 Page_Load 先于 Master Page 的 Page_Load,所以,如果要访问 Master Page 里的服务器控件,则必须在内容页面的 Page_LoadComplete 方法里书写代码。
12. 使用缓存

只有在内容页面才可以使用如下的 directive 指定缓存:

<%@ OutputCache Duration=”10″ Varybyparam=”None” %>

(这个指令让服务器在内存里缓存该页面 10 秒钟)

如果对 Master Page 指定该指令,本身并不会引发错误。但是当他的子页面下一次来获取其 Master Page 的时候,如果这时 Master Page 已经过期,则会引发一个错误。
所以实际上只能对子页面指定缓存。

Categories: ASP.net Tags:

ie6中hover伪类的兼容性问题

April 11th, 2011 Tony hu No comments

在IE6中,因为只支持css1,而hover伪类在css1中只支持<a>标签使用,其他标签一概不接纳,今天我们就来破除这个可恶的规矩!

第一步
 
打开记事本,复制如下代码:
 
<attach event=”ondocumentready” handler=”parseStylesheets” />
<script>
/**
* Whatever:hover – V1.42.060206 – hover & active
* ————————————————————
* (c) 2005 – Peter Nederlof
* Peterned – http://www.xs4all.nl/~peterned/
* License – http://creativecommons.org/licenses/LGPL/2.1/
*
* Whatever:hover is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Whatever:hover is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* Credits and thanks to:
* Arnoud Berendsen, Martin Reurings, Robert Hanson
*
* howto: body { behavior:url(“csshover.htc”); }
* ————————————————————
*/
var csshoverReg = /(^|\s)(([^a]([^ ]+)?)|(a([^#.][^ ]+)+)):(hover|active)/i,
currentSheet, doc = window.document, hoverEvents = [], activators = {
onhover:{on:’onmouseover’, off:’onmouseout’},
onactive:{on:’onmousedown’, off:’onmouseup’}
}
function parseStylesheets() {
if(!/MSIE (5|6)/.test(navigator.userAgent)) return;
window.attachEvent(‘onunload’, unhookHoverEvents);
var sheets = doc.styleSheets, l = sheets.length;
for(var i=0; i<l; i++)
parseStylesheet(sheets[i]);
}
function parseStylesheet(sheet) {
if(sheet.imports) {
try {
var imports = sheet.imports, l = imports.length;
for(var i=0; i<l; i++)
parseStylesheet(sheet.imports[i]);
} catch(securityException){}
}
try {
var rules = (currentSheet = sheet).rules, l = rules.length;
for(var j=0; j<l; j++) parseCSSRule(rules[j]);
} catch(securityException){}
}
function parseCSSRule(rule) {
var select = rule.selectorText, style = rule.style.cssText;
if(!csshoverReg.test(select) || !style) return;
var pseudo = select.replace(/[^:]+:([a-z-]+).*/i, ‘on$1′);
var newSelect = select.replace(/(\.([a-z0-9_-]+):[a-z]+)|(:[a-z]+)/gi, ‘.$2′ + pseudo);
var className = (/\.([a-z0-9_-]*on(hover|active))/i).exec(newSelect)[1];
var affected = select.replace(/:(hover|active).*$/, ”);
var elements = getElementsBySelect(affected);
if(elements.length == 0) return;
currentSheet.addRule(newSelect, style);
for(var i=0; i<elements.length; i++)
new HoverElement(elements[i], className, activators[pseudo]);
}
function HoverElement(node, className, events) {
if(!node.hovers) node.hovers = {};
if(node.hovers[className]) return;
node.hovers[className] = true;
hookHoverEvent(node, events.on, function() { node.className += ‘ ‘ + className; });
hookHoverEvent(node, events.off, function() { node.className = node.className.replace(new RegExp(‘\\s+’+className, ‘g’),”); });
}
function hookHoverEvent(node, type, handler) {
node.attachEvent(type, handler);
hoverEvents[hoverEvents.length] = {
node:node, type:type, handler:handler
};
}
function unhookHoverEvents() {
for(var e,i=0; i<hoverEvents.length; i++) {
e = hoverEvents[i];
e.node.detachEvent(e.type, e.handler);
}
}
function getElementsBySelect(rule) {
var parts, nodes = [doc];
parts = rule.split(‘ ‘);
for(var i=0; i<parts.length; i++) {
nodes = getSelectedNodes(parts[i], nodes);
} return nodes;
}
function getSelectedNodes(select, elements) {
var result, node, nodes = [];
var identify = (/\#([a-z0-9_-]+)/i).exec(select);
if(identify) {
var element = doc.getElementById(identify[1]);
return element? [element]:nodes;
}
var classname = (/\.([a-z0-9_-]+)/i).exec(select);
var tagName = select.replace(/(\.|\#|\:)[a-z0-9_-]+/i, ”);
var classReg = classname? new RegExp(‘\\b’ + classname[1] + ‘\\b’):false;
for(var i=0; i<elements.length; i++) {
result = tagName? elements[i].all.tags(tagName):elements[i].all;
for(var j=0; j<result.length; j++) {
node = result[j];
if(classReg && !classReg.test(node.className)) continue;
nodes[nodes.length] = node;
}
}
return nodes;
}
</script>
 
然后保存为hover.htc
 
 
第二步
 
在css文件中插入一条【注意htc文件的路径】:
 
body { behavior: url(“hover.htc”) }
 
完成!
 
现在进去看看,是不是li:hover  、 p:hover 都能起效果了呢?好了,尽管发挥吧!有问题?
Categories: Asp, Css, Web standard Tags:

Asp.net中使用Cookie时用中文汉字引起的乱码

December 3rd, 2010 Tony hu 12 comments

在写入cookie前,将内容用HttpUtility.UrlEncode进行处理,读取后,再用HttpUtility.UrlDecode进行还原

Categories: ASP.net, Web Tags:

JS Calendar Date Picker 日期选择、日历、不连续日期

July 5th, 2010 Tony hu No comments

这两天一直为一件事苦恼,怎么使用日期选择器来选取几个不连续的日期,今天终于找到了。

http://nogray.com/calendar.php 【JavaScript Calendar Component】

当然,如果你有其它需要,这里有30个很Cool的Calendar Date Picker

http://www.edesignerz.net/tips-a-tricks/16700-show-time-30-jquery-calendar-date-picker-plugins

试一下!

Categories: Tools Tags: