Archive

Author Archive

结婚证

September 16th, 2011 Tony hu No comments

2011年9月14日,我和她领证成功,愉快奔向已婚生活。

Categories: Mylife 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:

2011 TO DO LIST

December 30th, 2010 Tony hu 17 comments

今天在QQ空间里看到一友人写了题为“2011年必须做的日常琐事”的日志,我突然意识到:2010年很快要去过了,而且就在这两天。按照近两年来养成的习惯,每年都会写一个TO DO LIST(2010、 2009)。今天一直在考虑我应该写些什么。当我们回头看过去写的TO DO LIST时,总觉得大部分事情都没有做到。现在想想如果做到那些,可以和国足进球一样的堪称奇迹。那今年的TO DO LIST一定是容易实现的,且必须实现的。

总的来说,2010年我过得非常丰富多彩。这一年我搬了家,从桂花新村搬到了东港新村;这一年我结束了我的单身生活,现在有人管了;这一年我换了工作,结束了两年多的SCL的工作;这一年我做了真正的老板,虽然一直以来很多人都叫我老板;2010年是精彩的,接下来的2011年是残酷的,但是我相信最终也一定是精彩的。不罗嗦了,以下是要2011年做到的。

  1. 让公司能赚钱;不难吧,我没有说要赚多少。
  2. 在苏州安个家;挺难的,不过我一定会实现。
  3. 健康快乐生活;健康很重要,要劳逸结合啊。
  4. 多吃水果蔬菜;好像这样比较健康。
  5. 尽量不要熬夜;无法量化,尽量在23点前睡觉即可。
  6. 尽量早点起来;虽然暂时不需要打卡,自己要管好自己。

好了,今年就写这六点吧,看看今年能否全部实现。最主要的是前两点,呵呵。

Categories: Myself Tags:

Thanks

December 13th, 2010 Tony hu No comments

这些天来,我的QQ签名更改得比较频繁,很多人都以为我要结婚了,其实不是这样的。两年前,我发布了著名的日志“我封笔了,以后不写日志了。”,两年间一直有朋友让我再写写日志啊,我一直忍着没有写。根据这个日志的精神,我应该在2010年1月写一个日志的,结果,我又忍了一年。今天我不想再忍了,那就,开始吧!

上个月29号,我们拿到了营业执照,今天去了国税和地税,最后的手续基本办好了,再过几天就领用发票了。

在这里我们要感谢为我们公司成立作出卓越贡献的人们:

按时间顺序排,各位不要有意见啊,呵呵!

  1. 感谢老朋友阿培,当年我在杭州厮混的时候,阿培给了我一个饭碗,没齿难忘。同时他给我很多工作经验和生活上的经验。如果没有他,我这两年的历史要改写了。
  2. 感谢老东家SCL,感谢SCL当时给我提供了宽松的工作环境,使我可以在工作之余做自己喜欢做的事。即使是到了现在我还是非常怀念在SCL的日子。
  3. 感谢原苏州家教吧的管理员沈丹和吴秋云,家教吧从这里开始。
  4. 感谢原家教吧客服小邱,家教吧网站后台功能开始丰富起来了。
  5. 感谢郭立明、姚变丽和郭向楠,感谢你们的帮助,一直很稳定。
  6. 感谢我徒弟叶伟芳,让我认识了现在的女朋友。
  7. 感谢我老哥胡宏,给我介绍了一个我不喜欢的好工作,这是我离开SCL的官方理由。
  8. 感谢腾大教育朱老师,为我们解答了很多问题,同时万忙中去帮我们看写字楼,还帮我们争取了一个星期的免费租期。
  9. 感谢我的朋友炜炜,在我们公司还没有成立时就介绍了一个小业务给我们,这对于我们来说意义重大。
  10. 感谢平江行政服务中心工商注册那边的一个阿姨,注册的时候麻烦了她很长时间,她最让我感动的话是:你们放心,今天我就算是加班,也会帮你们办完的。
  11. 感谢中国银行苏州分行的姓徐的大姐,问了很多问题,很耐心地回答,非常的平易近人,带病工作,义务加班,精神可嘉。
  12. 感谢我们的小杨会计,为我们每年节省了不少的开支。
  13. 感谢房东的负责人韩先生,做事负责,能为我们考虑。
  14. 感谢我的爸爸和妈妈,谢谢他们对我选择的理解和支持。
  15. 感谢我的从小玩到大的好朋友黄春峰帮我们公司设计了公司LOGO。
  16. 我们,当然不只是我一个人。感谢我的女朋友晓花对我一直以来的鼓励和帮助、并且和我一起同甘共苦。感谢她的一路陪伴和支持。
  17. 感谢我自己,辛苦了,打了这么多的字,想了大半天,唯恐将应该要罗列在这里特别感谢的人遗漏了。我想到后再补上啊,呵呵!!!

当然,还有很多很多人我要感谢的,如SCL80后、胡姐、聂开伟等等。

我们公司的名称为:苏州薇蓝计算机技术有限公司;地址:苏州市平江区中街路143号;

再次对以上朋友表示感谢!!!

本文首发于本人的QQ空间:http://user.qzone.qq.com/359898601/blog/1292255286

Categories: Mylife, Myself Tags: