index
OKLCH | 色板生成器
大前端 - 张鑫旭 | oschina在线工具 | 代码格式化工具 | JSON语法检查 | 插画-自定义
Bootstrap 编辑器:含 20个类别的 230+ 常用组件,在线修改CSS ,支持导出HTML 及源码
<link href="https://use.fontawesome.com/releases/v5.3.1/css/all.css" rel="stylesheet"> <link href="https://afeld.github.io/emoji-css/emoji.css" rel="stylesheet">
目录
2020-03-20
Data URI scheme
RFC2397中定义的Data URI scheme,目的是将一些小的数据,直接嵌入到网页中 目前Data URI scheme支持的类型有: data:text/plain,文本数据 data:text/html,HTML代码 data:text/html;base64,base64编码的HTML代码 data:text/css,CSS代码 data:text/css;base64,base64编码的CSS代码 data:text/javascript,javascript代码 data:text/javascript;base64,base64编码的Javascript代码 编码的gif图片数据 编码的png图片数据 编码的jpeg图片数据 编码的icon图片数据
+new Date() === new Date().getTime();
<label for='username' accesskey='N'></label>
optgroup标签:
<select>
<optgroup label="Swedish Cars">
<option value="volvo">Volvo</option>
<option value="saab">Saab</option>
</optgroup>
<optgroup label="German Cars">
<option value="mercedes">Mercedes</option>
<option value="audi">Audi</option>
</optgroup>
</select>
穿透鼠标事件
div {pointer-events: none};
chrome设置调试:
debugger;
F12 F8 F10 F11
2019-08-10
getElementById和querySelector方法的区别
getElementById和querySelector
getXXXByXXX 获取的是动态集合,querySelector获取的是静态集合。 简单的说就是,动态就是选出的元素会随文档改变,静态的不会,取出来之后就和文档的改变无关了。 如果只要一次查找就可得到元素时,首选getXXXByXXX ; 如果需要经过多级查找,才能得到元素时,首选querySelector;
2019-03-10
eslint规范代码
npm install -g ESLint eslint --init
flex
flex: none | [ <'flex-grow'> <'flex-shrink'> || <'flex-basis'> ]
vue在移动端限制放大和滚动
<meta name="viewport" content="width=device-width, minimum-scale=1.0, maximum-scale=1.0">
<meta name="app-mobile-web-app-capable" content="yes">
.el-row {
margin-bottom: 20px;
&:last-child {
margin-bottom: 0;
}
}
prettfy代码格式化
<link rel="stylesheet" href="css/prettify.css" />
<script src="js/prettify.js" type="text/javascript"></script>
显示行号
li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8 {
list-style-type: decimal !important;
}
html文本
<code class="lang-java">int x = 0;</code>
<code class="prettyprint lang-java">int x = 0;</code>
<pre class="prettyprint lang-java linenums">
</pre>
可选皮肤
prettify.css (default)
sunburst.css
desert.css
doxy.css
sons-of-obsidian.css
chrome 开发者工具 —> sources -> { } pretty print
bootstrap
c.有些状态不可能保存在客户端。例如,为了防止重复提交表单,我们需要在服务器端保存一个计数器。 如果我们把这个计数器保存在客户端,那么它起不到任何作用。
NativeScript实现在不用Webview的情况下,构建跨Android和iOS的平台应用。
以前各种PhoneGap,Cordova,Ionic等需要移动端原生Webview的支持,使用NativeScript让你只用js,xml,css就可以完成移动端开发。
2018-03-10
js本地存储解决方案(localStorage与userData)
定义tap手势
//do not prevent defaults if this is a tap gesture
var isTapPointer = input.pointers.length === 1;
var isTapMovement = input.distance < 2;
var isTapTouchTime = input.deltaTime < 250;
if (isTapPointer && isTapMovement && isTapTouchTime) {
return;
}
addEventListener与handleEvent
Mozilla 0.9.1 和 Netscape 6.1 之后的版本不但支持传递函数引用,也都允许直接把拥有 handleEvent 方法的对象作为 addEventListener 方法的第二参数。
这在 DOM Level 2 的接口定义中也已经做了说明:
http://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-EventListener
利用这个特性可以把任意对象注册为事件处理程序,只要它拥有 handleEvent 方法。
var o = {
handleEvent : function () {
alert('handleEvent executed');
}
};
element.addEventListener('click', o, false);
当定义对象封装的时候,可以直接将 this 指针传入:
var o = {
bind : function () {
element.addEventListener('click', this, false);
},
handleEvent : function () {
alert('handleEvent executed');
}
};
定义内部函数
var untils = (function() {
var me = {};
me.getTime = Date.now || function getTime () { return new Date().getTime(); };
//计算实际位置
me.offset = function (el) {
var left = -el.offsetLeft,
top = -el.offsetTop;
while (el = el.offsetParent) {
left -= el.offsetLeft;
top -= el.offsetTop;
}
return {
left: left,
top: top
};
};
me.extend = function(target, obj) {
for(var key in obj){
target[key] = obj[key];
}
};
//扩展属性值
me.extend(me, {
hasTransform: _transform !== false,
hasTouch: 'ontouchstart' in window,
});
//初始化并定义子属性值
me.extend(me.style = {}, {
transform: _transform,
transitionDelay: _prefixStyle('transitionDelay'),
});
return me; //返回值作为utils的函数
})();
//调用函数,而不是utils.me.getTime()
utils.getTime();
idtag = document.getElementById('tag');
var offset = utiles.offset(idtag);
匿名运行函数
(function() {
alert('do something!');
})();
列表浏览器style
var style = document.createElement('div').style;
for(var key in style) {
console.log(key + ' : " + style[key]);
}
Event
三类事件,三种创建和初始化
HTMLEvents : initEvent
MouseEvents: initMousrEvent
UIEvents : initUIEvent
监听event
document.getElementById('tag').addEventListener('tag', function(e) {
alert('tag event occur!');
}, false);
创建、初始化和触发事件
function genEvent() {
var event = document.createEvent('HTMLEvents');
event.initEvent('tag', false, false);
idTag.dispatchEvent(event);
}
npm安装
yum install nodejs yum install npm npm install -g bower npm install -global gulp npm install gulp --save-dev #全局 npm install -g grunt-cli npm install grunt --save-dev npm install load-grunt-tasks --save-dev npm list npm -global list npm config list npm config list -l 网络不行可以考虑一些国内的源试试,例如 npm config set registry="http://r.cnpmjs.org/" npm config set registry="http://registry.npm.taobao.org/" 升级到稳定版本 $ npm install -g n $ n stable
安装npm
1、下载源码,你需要在http://nodejs.org/下载 2、解压源码 tar zxvf node-v4.4.3-linux-x86.tar.gz 3、 编译安装 cd node-v4.4.3-linux-x86 ./configure --prefix=/usr/local/node make make install 4、 配置NODE_HOME,进入profile编辑环境变量 vim /etc/profile 设置nodejs环境变量, #set for nodejs export NODE_HOME=/usr/local/node export PATH=$NODE_HOME/bin:$PATH 运行: source /etc/profile 淘宝npm镜像 搜索地址:http://npm.taobao.org/ registry地址:http://registry.npm.taobao.org/ 1.临时使用 npm --registry https://registry.npm.taobao.org install express 2.持久使用 npm config set registry https://registry.npm.taobao.org // 配置后可通过下面方式来验证是否成功 npm config get registry // 或 npm info express
2018-03-04
字串处理
var a = new Array(1,2,3,4,5);
var str = arr.join('-'); /*数组转换为字串*/
var b = str.split('-'); /*字串转换为数组*/
var c = [6,7,8,9];
var d = a.concat(c); //连接数组
a.push(10);
a.pop();
a.sort();
a.reverse();
a.shift(); //删除第一个元素并返回值
a.unshift([11,12]); //在第一个元素前加一个值
a.slice(1,2); //返回字串片段
a.splice(4,1); //删除一个元素并返回值
a.toString(); //
类型转换
// 强制转换为Boolean 用 !! var bool = !!"c"; console.log(typeof bool); // boolean // 强制转换为Number 用 + var num = +"1234"; console.log(typeof num); // number // 强制转换为String 用 ""+ var str = ""+ 1234; console.log(typeof str); // string
CSS3中translate、transform和translation的区别和联系
translate: transform的一个方法, 元素从其当前位置移动,根据给定的 left(x 坐标) 和 top(y 坐标) 位置参数:
用法:transform: translate(50px, 100px);
-ms-transform: translate(50px,100px);
-webkit-transform: translate(50px,100px);
-o-transform: translate(50px,100px);
-moz-transform: translate(50px,100px);
transform:CSS3中主要包括
旋转:rotate() 顺时针旋转给定的角度,允许负值
rotate(30deg)
扭曲:skew() 元素翻转给定的角度,根据给定的水平线(X 轴)和垂直线(Y 轴)参数:
skew(30deg,20deg)
缩放:scale() 放大或缩小,根据给定的宽度(X 轴)和高度(Y 轴)参数:
scale(2,4)
移动:translate() 平移,传进 x,y值,代表沿x轴和y轴平移的距离
所有的2D转换方法组合在一起:
matrix() 旋转、缩放、移动以及倾斜元素
matrix(scale.x ,, , scale.y , translate.x, translate.y)
改变起点位置: transform-origin: bottom left;
综合起来使用:transform: 30deg 1.5 30deg 20deg 100px 200px;
transition: 允许CSS属性值在一定的时间区间内平滑的过渡,
需要事件的触发,例如单击、获取焦点、失去焦点等
transition:property duration timing-function delay;
property:CSS的属性,例如:width height 为none时停止所有的运动,可以为transform
duration:持续时间
timing-function:ease等
delay:延迟
注意:当property为all的时候所有动画
例如:transition:width 2s ease 0s;
2017-11-10
不定参数
function test(id, i) { }
当调用时可以只带一个参数:
test(id);
函数的另一种定义方式:
test = function(id,i) { )
不定参数的调用:
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
apply([thisObj[,argArray]])
不定参数名必须是arguments
fun.apply(object, arguments);
fun.call(object, arg1, arg2, arg3);
fun.apply(object, [arg1, arg2, arg3]);
SecureHeaders SecureHeaders 是 Twitter 送给 Web 开发者的一份大礼,作为一款 Web 安全开发工具,Secureheaders 能够自动实施安全相关的 header 规则,包括内容安全政策(CSP),防止 XSS、HSTS 等攻击,防止火绵羊(Firesheep)攻击以及 XFO 点击劫持等。
bower
{
bower config file:
bower.json
.bowerrc
'directory' : 'bowers'
}
配色方案
wget -Ogithub.vim http://www.vim.org/scripts/download_script.php?src_id=23147