域名与 https 相关

做了 nighca.me 的 https 支持。

github pages 对 https 的支持依然不给力,帮助文档的说法是不支持,事实上有支持,但是不支持自定义域名。

所以为了迁移到 https,把站点从 github pages 挪到了自己在 digitalocean 的机器上,国内访问前者本来就不快,所以算是破罐子破摔,速度基本没啥影响。顺便把域名从 dnspod 转移到了 cloudx…

Full Article

Static Properties in ES Class

问题

ES6 的 class 支持 static property 吗?

static property, 即类(class,在 JS 中即构造函数 constructor)上的静态属性,代码示例如下:

class MyClass {
  static myStaticProp = 42;

  constructor() {
    console.log(MyClass.myStaticPr…
Full Article

从实现一个 Event Emitter 说起

事件驱动(Event-driven)模型是 Javascript 编程中绕不过去的概念,事件发射器 (Event Emitter) 则是事件驱动模型的核心。Event Emitter 与 class(及其 inherit)很相似的是,几乎每一个稍大的前端项目都会把它实现一遍。大多数情况下它被抽象成一个 Emitter 类,通过实例方法提供事件绑定(on/bind)、事件触发(fire/trigg…

Full Article

HTML代码风格检查工具对比

作为一个前端,不可避免同时与三个语言打交道:JS、CSS 和 HTML。而 HTML,超文本标记语言,是其中可编程性最弱的,一直以来得到的关注都较少。加上浏览器对 HTML 逆天的容错支持,即使是错误百出的文档也可以在浏览器里边表现得中规中矩。这样的背景下,绝大部分被产出的 HTML 代码都存在着各种各样的小问题,比如缺少必要的元信息(meta),比如混乱的 class、id 或属性的取值格式;…

Full Article

php-ghost

这是什么鬼?
<?php

function getArray() {
  return array(1, 2, 3);
}

// 这样是ok的
$tmp = getArray();
$secondElement = $tmp[1];

// 这样会报错(PHP <5.4)
// PHP Parse error:  syntax error, unexpected '[' …
Full Article

移动端页面中的定位

本来页面中定位是一件很单纯的事,直接调用HTML5接口就是。

navigator.geolocation.getCurrentPosition(
    function (position) {
        // ...
    },
    onerror,
    options
);

但是这可能是浏览器的原生接口中最脆弱的一个,会因为各种原因失败,会提供不了足够的信息。然而对于移动…

Full Article

在git中使用differ-cli

differ-cli 是基于nodejs的文件diff工具,相比系统/git自带diff工具,优化了排版,并进行更智能的多行逐词比较。

要替换git自带的diff,在每次git diff时自动使用differ-cli,很方便:

  1. 安装differ-cli

    npm install -g differ-cli
    
  2. 包装适用于git调用的可执行文件differ-cli-wrapper

    vi ~/bin…
Full Article

一塌糊涂的睡眠以及各种奇怪的梦

最近没有一天早上醒来不是昏昏沉沉的,大概是赶上各种事,脑袋有点转不过来,夜里边的闲时计算资源于是也被利用起来,躺在床上一闭眼睛就跟搁电影院似的,画面、人物依次闪过,竟然还能凑成狗血情节。

所以如果能让自己少想点东西,应该会是个不错的技能。