Hello World

Just So So ...

在使用Git的过程中,有时可能会有一些误操作

比如:执行checkout -f 或 reset -hard 或 branch -d删除一个分支

结果造成本地(远程)的分支或某些commit丢失

可以通过reflog来进行恢复,前提是丢失的分支或commit信息没有被git gc清除

一般情况下,gc对那些无用的object会保留很长时间后才清除的

reflog是git提供的一个内部工具,用于记录对git仓库进行的各种操作

可以使用git reflog show或git log -g命令来看到所有的操作日志

恢复的过程很简单:

  1. 通过git log -g命令来找到我们需要恢复的信息对应的commit_id,可以通过提交的时间和日期来辨别

  2. 通过git branch recover_branch commit_id 来建立一个新的分支

这样,我们就把丢失的东西给恢复到了recover_branch分支上了

转自:http://www.oschina.net/code/snippet_127872_8813
PHP中获取文件扩展名的N种方法
从网上收罗的,基本上就以下这几种方式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
// 第1种方法:

function get_extension($file)
{
substr(strrchr($file, '.'), 1);
}

// 第2种方法:
function get_extension($file)
{
return substr($file, strrpos($file, '.')+1);
}
// 第3种方法:
function get_extension($file)
{
return end(explode('.', $file));
}
// 第4种方法:
function get_extension($file)
{
$info = pathinfo($file);
return $info['extension'];
}
// 第5种方法:
function get_extension($file)
{
return pathinfo($file, PATHINFO_EXTENSION);
}
阅读全文 »

亲爱的老婆大人:

我知道你现在可能很有压力,可能对自己现在的情况不是很满意,也可能厌倦了现在的生活,你可能也是这样觉得的。

我知道你现在的工作很不好做,你也很努力的, 可能现在的结果并不是你想要的。你觉得你的付出与回报不是很成比例,你觉得你做了这么多,可能还会招来别人的满意,妒忌等。我能理解你媳妇。

我知道你现在的辛苦与不容易,我知道我把你一个人留在大连,想想这样对你真的很不公平,我也想过很多次,我为什么要这么做,也有过很多次想回去的想法,无论如何,也要在你身边,陪着你,周末的时候可以一起睡懒觉,起来去海边溜达,可是我到现在还没有回到你身边,我也有自己的想法,现在的不容易,可能是为了以后打下基础。

我知道你现在的处境与困惑,你现在可能工作心思都没了。不过我认为那可能是你一时的想法,你可能会因为我以上提到的三条内容感到压力,无助,和苦恼。不过老婆。你一定会好起来的。以为我相信你。还有我这个不称职的老公在鼓励你。加油!

未完待续…..

本文转自:http://developer.51cto.com/art/201103/249694.htm

jQuery的.bind()、.live()和.delegate()之间的区别并非总是那么明显的,然而,如果我们对所有的不同之处都有清晰的理解的话,那么这将会有助于我们编写出更加简洁的代码,以及防止在交互应用中弹出错误。

DOM树

首先,可视化一个HMTL文档的DOM树是很有帮助的。一个简单的HTML页面看起来就像是这个样子:

事件冒泡(又称事件传播)

当我们点击一个链接时,其触发了链接元素的单击事件,该事件则引发任何我们已绑定到该元素的单击事件上的函数的执行。

$('a').bind('click', function() { alert("That tickles!") });

因此一个单击操作会触发alert函数的执行。

click事件接着会向树的根方向传播,广播到父元素,然后接着是每个祖先元素,只要是它的某个后代元素上的单击事件被触发,事件就会传给它。

在操纵DOM的语境中,document是根节点。

现在我们可以较容易地说明.bind()、.live()和.delegate()的不同之处了。

.bind()

$('a').bind('click', function() { alert("That tickles!") });

这是最简单的绑定方法了。JQuery扫描文档找出所有的$(‘a’)元素,并把alert函数绑定到每个元素的click事件上。

.live()

$('a').live('click', function() { alert("That tickles!") });

JQuery把alert函数绑定到$(document)元素上,并使用’click’和’a’作为参数。任何时候只要有事件冒泡到document节点上,它就查看该事件是否是一个click事件,以及该事件的目标元素与’a’这一CSS选择器是否匹配,如果都是的话,则执行函数。

live方法还可以被绑定到具体的元素(或“context”)而不是document上,像这样:

$('a', $('#container')[0]).live(...);

.delegate()

$('#container').delegate('a', 'click', function() { alert("That tickles!") });

JQuery扫描文档查找$(‘#container’),并使用click事件和’a’这一CSS选择器作为参数把alert函数绑定到$(‘#container’)上。任何时候只要有事件冒泡到$(‘#container’)上,它就查看该事件是否是click事件,以及该事件的目标元素是否与CCS选择器相匹配。如果两种检查的结果都为真的话,它就执行函数。

可以注意到,这一过程与.live()类似,但是其把处理程序绑定到具体的元素而非document这一根上。精明的JS’er们可能会做出这样的结论,即$(‘a’).live() == $(document).delegate(‘a’),是这样吗?嗯,不,不完全是。

为什么.delegate()要比.live()好用

基于几个原因,人们通常更愿意选用jQuery的delegate方法而不是live方法。考虑下面的例子:

$('a').live('click', function() { blah() });

// 或者

$(document).delegate('a', 'click', function() { blah() });

速度

后者实际上要快过前者,因为前者首先要扫描整个的文档查找所有的$(‘a’)元素,把它们存成jQuery对象。尽管live函数仅需要把’a’作为串参数传递以用做之后的判断,但是$()函数并未“知道”被链接的方法将会是.live()。

而另一方面,delegate方法仅需要查找并存储$(document)元素。

一种寻求避开这一问题的方法是调用在$(document).ready()之外绑定的live,这样它就会立即执行。在这种方式下,其会在DOM获得填充之前运行,因此就不会查找元素或是创建jQuery对象了。

灵活性和链能力

live函数也挺令人费解的。想想看,它被链到$(‘a’)对象集上,但其实际上是在$(document)对象上发生作用。由于这个原因,它能够试图以一种吓死人的方式来把方法链到自身上。实际上,我想说的是,以$.live(‘a’,…)这一形式作为一种全局性的jQuery方法,live方法会更具意义一些。

仅支持CSS选择器

最后一点,live方法有一个非常大的缺点,那就是它仅能针对直接的CSS选择器做操作,这使得它变得非常的不灵活。

欲了解更多关于CSS选择器的缺点,请参阅Exploring jQuery .live() and .die()一文。

更新:感谢Hacker News上的pedalpete和后面评论中的Ellsass提醒我加入接下来的这一节内容。

为什么选择.live()或.delegate()而不是.bind()

毕竟,bind看起来似乎更加的明确和直接,难道不是吗?嗯,有两个原因让我们更愿意选择delegate或live而不是bind:

Ÿ 为了把处理程序附加到可能还未存在于DOM中的DOM元素之上。因为bind是直接把处理程序绑定到各个元素上,它不能把处理程序绑定到还未存在于页面中的元素之上。

Ÿ 如果你运行了$(‘a’).bind(…),而后新的链接经由AJAX加入到了页面中,则你的bind处理程序对于这些新加入的链接来说是无效的。而另一方面live和delegate则是被绑定到另一个祖先节点上,因此其对于任何目前或是将来存在于该祖先元素之内的元素都是有效的。

Ÿ 或者为了把处理程序附加到单个元素上或是一小组元素之上,监听后代元素上的事件而不是循环遍历并把同一个函数逐个附加到DOM中的100个元素上。把处理程序附加到一个(或是一小组)祖先元素上而不是直接把处理程序附加到页面中的所有元素上,这种做法带来了性能上的好处。

停止传播

最后一个我想做的提醒与事件传播有关。通常情况下,我们可以通过使用这样的事件方法来终止处理函数的执行:

$('a').bind('click', function(e) {
e.preventDefault();
// 或者
e.stopPropagation();
});

不过,当我们使用live或是delegate方法的时候,处理函数实际上并没有在运行,需要等到事件冒泡到处理程序实际绑定的元素上时函数才会运行。而到此时为止,我们的其他的来自.bind()的处理函数早已运行了。

本文转载至 http://weiboria.sinaapp.com/?p=174

DOM中的window对象通过window.history方法提供了对浏览器历史记录的读取,让你可以在用户的访问记录中前进和后退。

从HTML5开始,我们可以开始操作这个历史记录堆栈。

History

使用back(), forward(),和go()方法可以在用户的历史记录中前进和后退

前进和后退

后退:

window.history.back();
这个方法会像用户点击了浏览器工具栏上的返回键一样。

同样的,也可以用以下方法产生用户前进行为:

window.history.forward();
移动到历史记录中特定的位置

你可以使用go()方法从session历史中载入特定的页面。

向后移动一页:

window.history.go(-1);
向前移动一页:

window.history.go(1);
类似的,你可以前进或者后退多页。

还可以通过检查浏览器历史记录的length属性来找到历史记录堆栈中的页面总数。

var numberOfEntries = window.history.length;
注意: IE支持向go()方法传URL参数。

添加和修改history实体

自Gecko2开始引入 (Firefox 4 / Thunderbird 3.3 / SeaMonkey 2.1)

HTML5引入了histtory.pushState() 和history.replaceState()这两个方法,他们允许添加和修改history实体。同时,这些方法会和window.onpostate事件一起工作。

使用history.pushState()方法来修改referrer,这种方法可以被用在经过修改状态后而为xmlhttpRequest对象创建的http header中。这个referrer会是创建XMLHttpRequest 时document的URL。

pushState 用于向 history 添加当前页面的记录,而 replaceState 和 pushState 的用法完全一样,唯一的区别就是它用于修改当前页面在 history 中的记录。

例子

假设http://mozilla.org/foo.html页面执行了一下JS

var stateObj = { foo: “bar” };
history.pushState(stateObj, “page 2”, “bar.html”);
这种方法将会使url地址栏显示http://mozilla.org/bar.html,但浏览器不会加载bar.html页面,即使这个页面存在也不会加载。

现在再次假设用户继续访问http://google.com,然后点击后退。这时,url地址栏将会,http://mozilla.org/bar.html,页面会得到popstate事件(chrome),这个状态对象会包含一个stateObj的copy。这个页面看起来像foo.html。+

这时,我们再次点击后退,URL将变成http://mozilla.org/foo.html,document将得到另一个popstate事件和为null的state对象。这次的返回动作并没有改变文档的内容。(也许会过一会尝试加载…chrome)

pushState方法

pushState()有三个参数:state对象,标题(现在是被忽略,未作处理),URL(可选)。具体细节:

state对象 – state对象是一个JavaScript对象,它关系到由pushState()方法创建出来的新的history实体。用以存储关于你所要插入到历史记录的条目的相关信息。 State对象可以是任何Json字符串。因为firefox会使用用户的硬盘来存取state对象,这个对象的最大存储空间为640k。如果大于这个数值,则pushState()方法会抛出一个异常。如果确实需要更多的空间来存储,请使用本地存储。
title —firefox现在回忽略这个参数,虽然它可能将来会被使用上。而现在最安全的使用方式是传一个空字符串,以防止将来的修改。或者可以传一个简短的标题来表示state
URL —这个参数用来传递新的history实体的URL,注意浏览器将不会在调用pushState()方法后加载这个URL。但也许会过一会尝试加载这个URL。比如在用户重启了浏览器后,新的url可以不是绝对路径。如果是相对路径,那么它会相对于现有的url。新的url必须和现有的url同域,否则pushState()将抛出异常。这个参数是选填的,如果为空,则会被置为document当前的url。
某种意义上来说,调用pushState()方法很像设置了window.location = “#foo”,这两者都会创建和激活另一个关联到当前document的history实体,但pushState()另外有一些优点:

l 新的url可以是任何和当前url同域的url,相比之下,如果只设置hash,window.location会保持在同一个document。

l 如果不需要,你可以不修改url。对比而言,设置window.location = “#foo”;仅产生新的history实体,如果你当前的hash不是#foo

l 你可以将任意的数据与你的新history实体关联。使用基于hash的方法,需要将所有相关的数据编码为一个短字符串。

注意,pushState()方法不会使hashchange时间发生,即使是新旧url只是hash不同。

replaceState()方法

history.replaceState() 用起来很像pushState(),除了replaceState()是用来修改当前的history实体而不是创建一个新的。这个方法有时会很有用,当你需要对某些用户行为作反应而更新一个state对象或者当前history实体时,可以使用它来更新state对象或者当前history实体的url。

popstate事件

当history实体被改变时,popstate事件将会发生。如果history实体是有pushState和replaceState方法产生的,popstate事件的state属性会包含一份来自history实体的state对象的拷贝

详见window.onpopstate

读取当前的state

读取现有state

当页面加载时,它可能会有一个非空的state对象。这可能发生在当页面设置一个state对象(使用pushState或者replaceState)之后用户重启了浏览器。当页面重新加载,页面将收到onload事件,但不会有popstate事件。然而,如果你读取history.state属性,将在popstate事件发生后得到这个state对象

var currentState = history.state;

Browsers: Tested and Working In

HTML5 Browsers

Chrome 8,9,10
Firefox 4
Safari 5
Opera 11
Safari iOS 4.3
HTML4 Browsers

IE 6,7,8,9
Firefox 3
Opera 10
Safari 4
Safari iOS prior to version 4.3

1,按Esc进入系统启动菜单,选择

1
Ubuntu, kernel 2.6.20-16-generic (recovery mode)然后按e。

2,在第二层菜单选择

1
kernel /boot/vmlinux-2.6.20-16-generic root=UUID=ae424e-bod0-475c-2342433 ro single

按下e进行编辑。

3,修改启动参数为

1
kernel /boot/vmlinux-2.6.20-16-generic root=UUID=ae424e-bod0-475c-2342433 rw single init=/bin/bash

然后按回车。

4,按b启动系统就可以进入single模式而不需要密码了。

5,如果忘记了密码,建议用passwd root命令修改密码变成888888,方便好记。

本文转自 http://keyknight.blog.163.com/blog/static/3663784020085334812928/

本文引用至我的老婆的日志
http://user.qzone.qq.com/393772330/blog/1329459359

周五大家应该是一个很期待的,因为工作了一个星期大家都想休息一下缓解一下自己的心情和去玩,但是很多人的周天都在办公室里度过的,因为他们觉得自己应该为自己的明天奋斗,想要现在比别人强,就需要好好的奋斗,现在如果就开始享受的话那明天在别人享受胜利果实的时候你就一无所有,然后就开始抱怨自己怎么没有机会,自己怎么命运不好,其实大家都是一样的,上帝是公平的,付出就会有收获,也许你的付出和你现在的收获不是成正比的,但是请不要气馁,因为好运好光顾你的,我现在把所有的时间用来工作,只希望我现在可以过的更好,可可以在我的暮年的时候除了物质上满足以外更在意的是,当我会想起来我这一生的可以感到很值得,第一次工作是什么时候,第一笔薪水,第一次升职,自己的第一桶金等等,我希望我的一生是精彩的,虽然大家都觉得平平凡凡,简简单单才是真。但是也要在平凡的生活里不要太安逸或者是迷失了自己,那你还来这个世界上干什么?最近看了一部电影叫《I DO》虽然是一部关于爱情的电影,但是里面李冰冰演绎的那个职场白领的人角色其实我很喜欢,YES I DO 我会继续做我喜欢而且比较擅长的事情,让我自己更快的实现我人身中给自己规定的一个又一个的目标。

##通过PHP pear 安装PHPUnit

安装PHPUnit最简单的方法是通过PHP paer 来安装,

1. 安装php pear

首先 下载 go-pear.phar
然后放到PHP的目录下,就是与php.exe 在同一个目录,

然后 进入php的目录 在命令行中运行

1
php go-pear.phar

这样一直回车下来就可以了。然后点击有生成的注册表文件 PEAR_ENV.reg 来注册环境变量。注册完环境变量就可以通过pear来安装PHPUnit了。

2. 安装PHPUnit

在命令行中输入

1
2
pear config-set auto_discover 1
pear install pear.phpunit.de/PHPUnit

这样就可以完成PHPUnit的安装了。
如果需要安装其他软件包,可以继续。
DBUnit, 用于测试数据。

1
pear install phpunit/DbUnit

如果需要其他的软件,可以到按照PHPUnit的用户手册来进行按照

0%