Last login: Tue Jan 28 13:54:15 on ttys001 roy@192 ~ % sudo -i Password: 192:~ root# open -n /Applications/Google\ Chrome.app/ --args --disable-web-security --user-data-dir=/Users/roy/MyChromeDevUserData/
月度归档:2020年03月
解决Mac每次都要执行source ~/.bash_profile 配置的环境变量才生效的问题
在~/.zshrc文件最后,增加一行:source ~/.bash_profile
如果没有 .zshrc 文件, 在相应目录下 执行 touch .zshrc 创建文件,添加 source ~/.bash_profile
mac下 composer 简洁的安装方法和简单使用
一. mac composer 安装
在命令行执行curl -sShttps://getcomposer.org/installer| php 如果没安装 curl 执行以下代码php -r “readfile(‘https://getcomposer.org/installer‘);” | php然后执行sudo mv composer.phar /usr/local/bin/composer修改 composer的权限sudo chmod a+x /usr/local/bin/composer注意sudo mv composer.phar /usr/local/bin/composer不用创建 composer 目录
二. 通过composer 安装laravel项目 tfApp 为自定义项目名称
composer create-project laravel/laravel ftApp –prefer-dist
导致position:sticky失效的原因
sticky 英文字面意思是粘,粘贴,所以姑且称之为粘性定位。下面就来了解下这个处于实验性的取值的具体功能及实用场景。 这是一个结合了 position:relative 和 position:fixed 两种定位功能于一体的特殊定位,适用于一些特殊场景。 什么是结合两种定位功能于一体呢? 元素先按照普通文档流定位,然后相对于该元素在流中的 flow root(BFC)和 containing block(最近的块级祖先元素)定位。 而后,元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。 这个特定阈值指的是 top, right, bottom 或 left 之一,换言之,指定 top, right, bottom 或 left 四个阈值其中之一,才可使粘性定位生效。否则其行为与相对定位相同。 当然,这个属性的兼容性也不是很好,所以如果你设置了position: sticky而不起作用的话,首先应当想到的是浏览器的兼容性问题,如果不是兼容性的问题,还有以下几种情况会导致这个属性失效 就是父元素的overflow属性值为:hidden auto scroll 或body height:100% 时, 解决方法:父元素不使用以上属性或子元素不使用position:sticky
来源:极客教程
ionic 打包安卓时提示Could not download fastutil.jar (it.unimi.dsi:fastutil:7.2.0):
把这段代码加入 build.gradle
buildscript {
repositories {
maven{ url "http://maven.aliyun.com/nexus/content/groups/public/"}
google()
}
}
allprojects {
repositories {
maven{ url "http://maven.aliyun.com/nexus/content/groups/public/"}
google()
}
}
php下载大文件
private function downloadFile($filename){
//获取文件的扩展名
$allowDownExt = explode('|', 'flv|mp4|avi|mov|avi|rmvb|mpeg|jpg|gif|png|psd|ai|doc|docx|ppt|pptx|xls|xlsx|pdf|zip|rar|7z|tar|cab');
//检测文件是否存在,并且可读
if(!is_file($filename) && is_readable($filename)) {
return false;
}
//获取文件的扩展名
$fileext=strtolower(pathinfo($filename,PATHINFO_EXTENSION));
//检测文件类型是否允许下载
if(!in_array($fileext,$allowDownExt)) {
return false;
}
//设置脚本的最大执行时间,设置为0则无时间限制
set_time_limit(0);
//通过header()发送头信息
//因为不知道文件是什么类型的,告诉浏览器输出的是字节流
header('content-type:application/octet-stream');
//告诉浏览器返回的文件大小类型是字节
header('Accept-Ranges:bytes');
//获得文件大小
$filesize=filesize($filename);
//告诉浏览器返回的文件大小
header('Accept-Length:'.$filesize);
//告诉浏览器文件作为附件处理并且设定最终下载完成的文件名称
header('content-disposition:attachment;filename=yangrl'.basename($filename));
//针对大文件,规定每次读取文件的字节数为4096字节,直接输出数据
$read_buffer=4096;
$handle=fopen($filename, 'rb');
//总的缓冲的字节数
$sum_buffer=0;
//只要没到文件尾,就一直读取
while(!feof($handle) && $sum_buffer<$filesize) {
echo fread($handle,$read_buffer);
$sum_buffer+=$read_buffer;
}
//关闭句柄
fclose($handle);
exit;
}