十五的学习日记20160925
十五的学习日记20160925
CSS
学过盒子布局的人都知道,元素之间的上下margin会合并,保留数值较大的margin作为渲染依据.
但是今天在群里讨论发现:
img元素和p元素的上下margin不会合并.
这可能表明可替换元素和其他元素的margin存在本质区别.
PHP
今天群里有人问我一个phpstorm提示的警告,代码如下
$a=0;
for($a;$a<20;$a++){
...}
IDE对for循环中第一个变量$a
的警告信息为:Expression result unused
(表达式结果未使用)
然而实际运行是可以通过的.
经过一番思考和尝试,结论是: for循环中的第一个$a
没有赋值操作,也没有别的操作,所以会显示表达式未被使用.所以改成以下形式,就不会警告啦:
$a=0;
for(;$a<20;$a++){//去掉了初始化声明,就不再警告.
...}
JavaScript
1判断奇偶新招
过去我判断奇偶基本靠除以2求余数来判断.
今天群里有人提了一个方法来判断奇偶:
按位与操作 代码&1==0
,返回 true就是偶数,返回false就是偶数.
2数组排序&去重新思路.
昨晚翻了一遍所有的Array.prototype
方法,想了一个新招来处理数组排序&去重,代码如下:
function reducedup(array){if(array.constructor.name!="Array"){array=array.toString().split("");}return array.sort(function (a,b) {return a-b;}).filter(function (el,i,arr) {if((i<arr.length-1)&&el!==arr[i+1]||(i==arr.length-1)&&el!==arr[i-1]){return el;}});
}
reducedup("8543217486765379534279089865314");
3读书笔记
可调用对象不一定是函数对象
a function is referred to as a “callable object”—an object that has an internal [[Call]] property that allows it to be invoked.
函数是一个可调用对象,也就是说,是一个具有内建特性[call]
的对象,以至于让它可以被调用.It’s most appropriate to think of them also as a “subtype” of object (see Chapter 3), in this case with the additional characteristics of being numerically indexed (as opposed to just being string-keyed like plain objects) and maintaining an automatically updated .length property.
(数组)可以适当地把它想象成是Object类型的子类, 并加上了一些额外的性质,比如拥有可数下标,比如自动增长的.length属性.An “undefined” variable is one that has been declared in the accessible scope, but at the moment has no other value in it.
未定义变量是一个已经在特定作用域中被声明的,而尚未被赋值的变量.from <You Don't know JS: type&grammar>
4今日要点:
String
也有concat
方法,操作规则和Array
一样.Array.from
可以直接转化一个伪数组为数组.- 可以通过
Array.prototype.method.call(伪数组,etc)
的方式来对伪数组使用数组的方法
String
也是一种伪数组,不过因为String
本身具有值的不可变性, 所以只能使用生成新数组的方法,而不能用改变String
本身的方法. Number.prototype.toFixed(int)
返回固定小数点int位置的值,并且转换为String
.
Number.prototype.toPrecision(int)
也有同样效果,只不过他计算的是整个数值的长度.
var a = 42.59;
a.toFixed( 0 ); // "43"
a.toFixed( 1 ); // "42.6"
a.toFixed( 2 ); // "42.59"
a.toFixed( 3 ); // "42.590"
var a = 42.59;
a.toPrecision( 1 ); // "4e+1"
a.toPrecision( 2 ); // "43"
a.toPrecision( 3 ); // "42.6"
a.toPrecision( 4 ); // "42.59"
- 由于编程语言普遍存在
0.1+0.2!=0.3
的情况.
所以在ES6提供了浮点数比较办法:主要用了柯西式的极限定义来比较.
function numbersCloseEnoughToEqual(n1,n2) {
return Math.abs( n1 - n2 ) < Number.EPSILON;}
var a = 0.1 + 0.2,b = 0.3;
numbersCloseEnoughToEqual( a, b ); // true
numbersCloseEnoughToEqual( 0.0000001, 0.0000002 ); // false
Number.MAX_VALUE
和Number.MAX_SAFE_INTEGER
是两回事.void
something
可以阻止赋值,替换为undefined
输出.(ES6)NaN
是数,但不存在相等性.也不能通过window.isNaN
来辨别,因为window.isNaN("b")
也返回true.
不过ES6给出了Number.isNaN
复了这个bug.
另一条思路是改写window.isNaN
为:
isNaN = function(n) {return n !== n;};
- 除非该属性特性设置为不可修改,一切方法都不可完全相信,如果遇到无法排查的bug,一定要注意这点.
- 几条有趣的计算
Infinity *or+ Infinity //Infinity
Infinity /or- Infinity //NaN
Infinity/0 //Infinity
Infinity*0 //NaN
1/Infinity //0
0/-3 //-0
JSON.stringify( -0 ); // "0"
JSON.parse( "-0" ); // -0
-0===0 //true
程序员英语
You obviously must first convert
(coerce)
the value from number to string.
显然地你必须首先将这个值从数值型(强制地)转换成字符型to be considered a flaw in the design of the language, to be
shunned
and avoided.
这被认为是一个语言设计时造成的失误,应当被避免和制止.The value 42 has an
intrinsic
type of number, and its type cannot be changed
数值42天生拥有number类型本质,并且无法被改变.- It’s
tempting for
most developers to think of the word “undefined” as asynonym
for “undeclared.”
这很容易诱导开发者把单词"未定义"看作是"未声明"的同义词. - JavaScript has some unique characteristics with these types that may either delight or
confound
you.
在这些类型上,js有着一些独特的性质,可能会启发你或迷惑你. However, a
gotcha
to be aware of is that if a string value intended as a key can be coerced to a standard base-10 number
要明白的一点是,如果你想用一个字符串型的值作为键值,那它会被强制转换成10进制数.
Coerce
:强制,强迫;
Shunned
:避免,躲开;
intrinsic
固有的本质的;
tempting for
引诱,诱导;
synonym
同义词;
confound
:迷惑,困惑.
gotcha
:=got you=明白;
不写了...太麻烦,今天先到这里.
转载于:https://www.cnblogs.com/always-naive/p/5933826.html
十五的学习日记20160925相关推荐
- 十五的学习日记20160926-你不知道的JS笔记/
十五的学习日记20160926 JavaScript 一个用于检测正负值的函数,可以用它辨别-0值. 我觉得挺好用,以后可以写到自己的工具库里. //函数:检查传入参数是否为正数.Number=> ...
- 第十五周学习周记——微信小程序开发初步
第十五周学习周记 前言 一.小程序简介 二.小程序代码构成 1. JSON配置 2. WXML模板 3. WXSS样式 4. JS逻辑交互 总结 前言 这一周将开始微信小程序的学习. 一.小程序简介 ...
- 第十五周学习周报(20180611-20180617)
第十五周学习周报 一.本周学习情况 1.本周主要学习李宏毅老师的机器学习课程 Backpropagation Convolutional Neural Network Semi-supervised ...
- 201771010137 赵栋《面向对象程序设计(java)》第十五周学习总结
实验十五 GUI编程练习与应用程序部署 实验时间 2018-12-6 一:理论部分. 1.Java 程序的打包:编译完成后,程序员将.class 文件压缩打包为 .jar 文件后,GUI 界面序就可 ...
- 2017面向对象程序设计(Java)第十五周学习总结
上周,老师要求同学们自学应用程序部署,并布置了相关的实验任务.此次实验的目的是掌握Java应用程序的打包操作:了解应用程序存储配置信息的两种方法: 了解Applet小应用程序的开发及应用方法:掌握基于 ...
- 【软件开发底层知识修炼】十五 快速学习GDB调试二 使用GDB进行断点调试
上一篇文章我们学习了使用GDB的最基本方法:[软件开发底层知识修炼]十四 快速学习GDB调试一 入门使用 本篇文章将学习GDB的断点调试.断点调试是一种非常重要的调试方法. 文章目录 1 断点类型 2 ...
- 软件工程--第十五周学习进度
第十五周 代码量 245 所花时间 6h 博客量 3篇 了解到的知识点 搭建基本web,了解了服务器的配置过程,也开始为自己的项目投入基金. 转载于:https://www.cnblogs ...
- 推荐系统遇上深度学习(十五)--强化学习在京东推荐中的探索
强化学习在各个公司的推荐系统中已经有过探索,包括阿里.京东等.之前在美团做过的一个引导语推荐项目,背后也是基于强化学习算法.本文,我们先来看一下强化学习是如何在京东推荐中进行探索的. 本文来自于pap ...
- 第二十五篇 -- 学习第三十四天打卡20190726
学习书籍<剑桥商务英语中级词汇精选>乱序版 Day05 Day30proprietor [prə'praɪətə(r)] n.所有者,经营者例:The proprietor is resp ...
最新文章
- ijkplayer-丢帧策略深入分析
- 经典推荐:《Silverlight揭秘》和《ASP.NET 3.5高级程序设计(第2版)》
- 我说分布式事务之最大努力通知型事务
- asp.net 中文编码问题
- 根据dtd编写xml的小例子
- 转录组分析综述A survey of best practices for RNA-seq data analysis
- 面经——Linux相关
- Berttransformer
- u盘装linux fail load,安装ubuntu18.04报:failed to load ldlinux.c32的问题及解决步骤
- 运动matlab分析机械振动,《运用Matlab分析机械振动》-毕业论文.doc
- 织梦采集侠破解版_最新dedecms织梦采集侠v2.6破解版
- 电商产品经理:电商后台系统
- 金士顿U盘修复工具Kingston Format Utility
- 风行播放器2014 v3.0.1 正式版
- python实现LU分解与LUP分解
- 【python爬虫】Python爬取下载巨潮网指定公司的年报pdf
- 我认为还算经典的语录
- java跳转页面_几种方式实现Javaweb页面跳转
- 第1章 Kotlin是什么
- [渝粤教育] 重庆工商职业学院 生活中的大数据 参考 资料
热门文章
- 在eclipse中使用git创建本地库,以及托管项目到GitHub超详细教程
- python处理中文编码问题总结
- C#绘图双缓冲技术总结(转)
- [导入]asp.net2.0乱记(33)vista下使用vs2005及一些软件
- Agile Framework的专区上线
- 汽车编程都是用matlab,MATLAB编程与汽车仿真应用
- Java多线程(一)——多线程实现方法和生命周期
- one大白陪你聊聊2021年总结
- Transformations on DStreams之transform的使用 实现黑名单操作/指定过滤
- Kafka模拟实现(用于自我测试环境)