1. gitignore填写规则不生效
是因为在git忽略目录中,新建的文件在git中会有缓存,
如果某些文件已经被纳入了版本管理中,就算是在.gitignore中已经声明了忽略路径也是不起作用的,
这时候我们就应该先把本地缓存删除,然后再进行git的提交,这样就不会出现忽略的文件了。
git状态
Untracked:
未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged.
Unmodify:
文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改,
而变为Modified. 如果使用git
rm
移出版本库, 则成为Untracked文件
Modified:
文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过git add可进入暂存staged状态,
使用git checkout 则丢弃修改过, 返回到unmodify状态, 这个git checkout即从库中取出文件, 覆盖当前修改
Staged:
暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为Unmodify状态.
执行git reset HEAD filename取消暂存, 文件状态为Modified
Git 状态 untracked 和 not staged的区别
1)untrack 表示是新文件,没有被add过,是为跟踪的意思。
2)not staged 表示add过的文件,即跟踪文件,再次修改没有add,就是没有暂存的意思
2. GET缓存
今天遇到一个问题,就是通过get请求一个文件A的时候,A文件修改之后,get请求到的依旧是修改前的文件。
这个就是get的缓存问题导致的
然后就想说在生成A文件的时候加上一个时间戳,方法可行,但是这样就会导致会生成n个A文件,在下次生成的时候还需要删除掉历史文件
最终决定在get请求上加上?t=(new Date()).getTime(); 解决了这个问题。
3. 获取时间戳的3种方式
Date.parse(new Date()); 这种方式在ts中不能使用会报错
(new Date()).getTime();
(new Date()).valueof();
4. fs删除目录和文件
删除目录: rmdirSync() 该方法只可以删除空目录,所以在使用的时候需要递归删除
删除文件: unlinkSync()
function deleteFolderRecursive (path) {
var files = [];
if( fs.existsSync(path) ) {
files = fs.readdirSync(path); //读取path下面的所有文件
files.forEach(function(file,index){
var curPath = path + "/" + file;
if(fs.statSync(curPath).isDirectory()) { // recurse
deleteFolderRecursive(curPath);
} else { // delete file
fs.unlinkSync(curPath);
}
});
fs.rmdirSync(path);
}
};
5. eggjs在webstorm中不会热更新的问题
用egg-shell-decorators和eggjs部署了一个后端项目,但是每次修改文件之后,webstorm都不能自动进行热更新。
解决办法是在 file -> settings -> systemSettings将 Use "safe write" 勾选去掉,就可以实时进行更新了