2017年6月

很多人说毛带兵成功治国失败,不理解他的三反五反十年浩劫。然而毛确实是一个共产主义者,理想主义者,甚至是完美主义者。他所做的确实是消灭阶级,消灭不公平,将整个国家高出中农以上的阶级全部铲平,在生前建立共产乌托邦。只是我们后来才注意到,乌托邦世界的问题。

人类发展技术,个体让后代学习技术,意图让他们过上更美好的生活,甚至走上“共同富裕”。然而,个体更美好其实只是个概率问题,好的技术并不能一定保证好的生活,也无法让你过得更轻松,也无法共同富裕,而总是一部分富裕了另一部分没有,而后代只能像赌博一样压宝,总盘子就这么大,看你们的运气。心理学说人人都会做出对他来说最好的选择,而他们只是选择了自己最好的押宝。
当技术不起作用了,人类说你还得努力,未成年努力还不够,还得终身努力。然后你就放弃了舒适的生活,去过“好的生活”,房车票子上流社会之类。大家都努力,总盘还这么大,你就只有更加辛苦才能获得跟以前差不多的生活。
最终,你努力学了技术,又努力工作,生活却还是不如意,感叹或咒骂人生究竟如此苦逼的时候, 人类给你三个选择:一,宗教,人生就是痛苦,这辈子幸福是不可能了, 不过下辈子可以, 只要你信教, 就能上天堂,得永生;二,你自己是不可能了, 但你的子女可以, 总得让自己子女过得好一些,轻松一些, 所以继续努力吧,希望在未来;三,人生得有理想,得改变世界什么的, 万一实现了呢, 所以继续努力吧。每个人需求不同, 有的要救自己, 有的要救后代, 有的要救世界, 总有一个满足你. 不过相对来说, 宗教这个没让你继续过度疲劳, 所以还是划算些, 这门生意从图腾时代开始也就兴旺了几万年不衰. 中国皇帝最大, 宗教最多当过老二, 于是只好寄托后代, 所以不孝有三无后为大, 所以传宗接代重男轻女, 因为只有男性能代表我实现幸福生活.
至于理想主义, 是一个适合文青的方式, 古代受教育的少, 文青也少, 所以一直是个配角, 现代纷纷读起了大学博士研究生, 才变得更加流行起来了. 现代文青受教育多了, 一是导致家族观念淡薄, 都想实现个自我价值; 二是广告和小时代看得多了, 要买要用的东西多, 生活压力大, 就不愿意多生孩子养家. 所以只有理想主义能拯救他们. 他们喜欢乔帮主的"卖个糖水还是拯救世界"的段子, 纷纷开始实现王健林的"1个亿小目标". 其实理想主义也是贯穿古代的文青圈, "穷则独善其身, 达则兼济天下". 只是比较起来, 古代人还是现实一些, 穷了还就只管自己了, 有钱了也只是"兼"济天下, 顺带地救一下世界. 现代文青就不一样, 我穷也要或者更要救天下,救不了天下也得在天底下扬名立万, 并时时以救天下的各种鸡汤段子鞭策自己, 鞠躬尽瘁死而后已.
最后谁赢了?只是那物竞天择的自私基因。

仿真一般都用Proteus, 原理图到PCB都能搞定;
MCU这么几个系列:
C51, 开发环境Keil for C51. 著名开发公司Atmel, 还有国内的STC.
MSP430, TI公司的, 主流两个, 一个是TI自己的CCS编译环境, 另一个是IAR Embedded Workbench for MSP430
AVR, Atmel的芯片, 自家的编译环境有Atmel Studio/toolchain, v5版本以前叫做AVR studio.
ARM, 一般是Keil For MDK. STM32也是基于ARM的Cortex M3的.
STM8, 一般是IVR for STM8, ST公司自家的STVD也可以
PIC, Microchip公司,用 MPLAB X IDE

如果用Vue属性做v-for的话, 注意它不能检测对象属性的直接增删, 而是要用Vue.set来增删对象属性.
另外, 在v-for场景下, 数组可以很方便的只显示部分或者做过滤/排序等, 对象就不行了. 所以使用v-for尽量将数据类型设计为数组.

vue-router默认是需要将项目放在服务器的根目录下的, 在浏览器里输入域名是这样:

http://mydomain.com/

vue怎么确认去服务器取数据还是在本地取数据呢? 其实借助的是井号"#", 井号在url中指向的是自己, 而不会去服务器取数据. 如下url, 是在根目录下的vue应用中, 也就是在vue-router中被导航.

http://mydomain.com/#/login

而如下url,将会到服务器上去取数据

http://mydomain.com/login

但如果要放置在子目录下呢, vue应用放在productinfo目录中:

http://mydomain.com/productinfo/#/login

需要两步:
1. 需要配置 router的config:

const RouterConfig = {
    base: 'productinfo'
};
const router = new VueRouter(RouterConfig);
  1. vue-router一般都是用vue-cli或者webpack, 做多个文件打包的, 也就是运行:

    npm run build

可以打包app. 当然, package.json中需要有对应的build配置, 如下:

  "scripts": {
    "build": "webpack --progress --hide-modules --config webpack.prod.config.js",
  },

那么在webpack.prod.config.js中, 也需要配置路径, 否则默认应用的打包文件就会出错.
以前是

    output: {
        publicPath: '/dist/',
    },

现在改为:

    output: {
        publicPath: '/productinfo/dist/',
    },

重新打包npm run build就好了.

附webpack.prod.config.js完整文件:

const webpack = require('webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const merge = require('webpack-merge');
const webpackBaseConfig = require('./webpack.base.config.js');
const fs = require('fs');

fs.open('./src/config/env.js', 'w', function(err, fd) {
    const buf = 'export default "production";';
    fs.write(fd, buf, 0, buf.length, 0, function(err, written, buffer) {});
});

module.exports = merge(webpackBaseConfig, {
    output: {
        publicPath: '/productinfo/dist/',
        filename: '[name].[hash].js',
        chunkFilename: '[name].[hash].chunk.js'
    },
    plugins: [
        new ExtractTextPlugin({
            filename: '[name].[hash].css',
            allChunks: true
        }),
        new webpack.optimize.CommonsChunkPlugin({
            name: 'vendors',
            filename: 'vendors.[hash].js'
        }),
        new webpack.DefinePlugin({
            'process.env': {
                NODE_ENV: '"production"'
            }
        }),
        new webpack.optimize.UglifyJsPlugin({
            compress: {
                warnings: false
            }
        }),
        new HtmlWebpackPlugin({
            filename: '../index_prod.html',
            template: './src/template/index.ejs',
            inject: false
        })
    ]
});

超微型接口, 一般是IPX/IPEX/IPAX/AMC/UMCC/MHF/Hirose H.FL... 哦, 真搞不清楚这么个接口居然有如此之多的名字... 这是日本公司Hirose的专利接口, 不过用的实在是太多了...
尺寸上似乎有多种类型. 淘宝常见的似乎是331.5MM的. 阻抗50Ω.传输频率 0~6GHz.

普通结构, 一般是SMA, 是SubMiniature version A的简称, 传输频率 0~18GHz, 阻抗50Ω.直径约6mm.

SMA容易和F头(F connector)混淆. F头阻抗75Ω,直径9.5mm. 典型传输频率0~0.75GHz. 不过到2.2GHz似乎也没有问题.

Q9/BNC接口也常用于接天线.

TNC(Threaded Neill–Concelman)接头, 是BNC接头的螺纹版. 50Ω/0~11GHz. 微波段比BNC表现好. 公口1.5厘米,母口1厘米.

N接头(N Connector), 0~11GHz,有50Ω和75Ω版本. 公口直径有2.03厘米, 母口直径有1.57厘米, 是比较大的接口.

其他:
1. J一般表示公头, K表示母头.
2. SMA和TNC都有RP版. RP是Reverse Polarity的简称,即"反极性".
* 正常版内螺纹端(公头)有针, 外螺纹端(母头)无针.
* RP版的内螺纹端无针, 外螺纹端有针.

pug与stylus虽然看起来写起来都很简洁,然而由于像sublime text这样的编辑器已经对html自动补全支持得很好了, pug和stylus在还没有自动补全的时候, 书写效率未必比原生html和css更快

pug示例:

div.className1.className2(style='font-size:37px') test ok!

stylus示例

.className1
    color: green
.className2
    background-color: red

1、npm install xxx-loader --save-dev,如:以前叫jade现在叫pug的:

npm install pug-html-loader

2、在webpack.base.config.js中加入配置:

module:{
  rules: [{
              test: /\.pug/,
              loader: ['raw-loader', 'pug-html-loader']
  }]
}

3、使用。如在vue的模板中:

科技永远打着造福人类的旗号。
可它却只是为了压榨人类,发展自己。
农业革命,大部分人类丧失了空闲,必须日日面朝黄土背朝天;阶级产生,只有皇帝和祭司无需劳动。
工业革命,人类丧失了土地,必须日日面对机器;农民打砸机器,希望换回曾经的生活。
信息革命,人们连机器也丧失了,产线上只有机器人;人们开始咒骂全球化,想要要回自己的工作。
人工智能革命,人们连决策力也丧失了,不需要做决定,司机失业,更多需要做决定的工作都失业了。人们又将咒骂什么,又将如何生存?