Tips and Tricks(小技巧)
console(控制台)
运行多行的命令
Shift
+ Enter
允许您在控制台输入多行。
data:image/s3,"s3://crabby-images/b2329/b2329d7d3a4524eeeebd8fa90ba334332fbf50cc" alt="编写多行的javascript程序"
data:image/s3,"s3://crabby-images/93083/930830b01ea3307f5e418d98015a062dce33d500" alt="编写多行的javascript程序"
Snippets了解更多关于多行代码持久使用的方法。这个功能可以执行自定义的javascript片段,并将其存储在DevTools中。
启动元素审查的快捷方式
Ctrl
+ Shift
+ C
或 Cmd
+ Shift
+ C
将快速启动 DevTools
检查元素的模式。
data:image/s3,"s3://crabby-images/070b1/070b1a0fbd06aaead30aa3ea6f7c3b58329ae181" alt="快速启动审查元素的模式"
支持 console.table 命令
使用如下:
console.table([{a:1, b:2, c:3}, {a:"foo", b:false, c:undefined}]);
console.table([[1,2,3], [2,3,4]]);
data:image/s3,"s3://crabby-images/d663d/d663d1dbc94c546c172ad47303f0252be616025f" alt="console.table 命令"
还有一个可选的 columns
参数来选择需要输出的列。
如下:
function Person(firstName, lastName, age) {
this.firstName = firstName;
this.lastName = lastName;
this.age = age;
}
var family = {};
family.mother = new Person("Susan", "Doyle", 32);
family.father = new Person("John", "Doyle", 33);
family.daughter = new Person("Lily", "Doyle", 5);
family.son = new Person("Mike", "Doyle", 8);
console.table(family, ["firstName", "lastName", "age"]);
data:image/s3,"s3://crabby-images/697fd/697fdb665aa32aaf334376da23bceadad33bffe6" alt="console.table 命令"
如果只想输出出前两列,可以:
console.table(family, ["firstName", "lastName"]);
预览在控制台打印出的对象
可以直接使用console.log()预览打印出的对象,不需要做额外的工作。
data:image/s3,"s3://crabby-images/8652d/8652d7e9cc6e3fefe1ef517823c819b9ad4155b9" alt="预览打印出的对象"
传递多个参数控制打印日志的样式
你可以通过 %c
将样式添加到您的控制台日志,就像你可以在Firebug中做的一样。如:
console.log('%cBlue! %cRed!', 'color: blue;', 'color: red;');
data:image/s3,"s3://crabby-images/74c96/74c969c7fe0192ac0613034a6d44d36482e4bbc2" alt="酷酷的控制台日志啊"
More: Styled Console Logging In The DevTools | G+
清空控制台历史的快捷键
Ctrl
+ L
and Cmd
+ L
快捷键. 在 shell 中 clear()
命令也可以。 javascript中的console.clear()也是可以的。
做一个键盘侠
Devtools
打开并获得焦点时时,Shift
+ ?
命令打开一个设置面板,选择 shortcuts
可以看到所有可用的快捷键
data:image/s3,"s3://crabby-images/d83da/d83daa8cbefa65891322bfb0babbc4f93d3011fc" alt="查看快捷键"
从控制台快速的选择元素
Select an element and type $0 in the console, it will be used by the script. If you have jQuery on the page, you can then use $($0) to reselect the element in the page.
data:image/s3,"s3://crabby-images/97d5f/97d5f8d095ae609fd2212e5869090b3f88730f78" alt="快速选择元素"
You can also right click on any element output to the console and click 'Reveal in Elements Panel' to find it in the DOM.
data:image/s3,"s3://crabby-images/0f4f2/0f4f2cd261c08a9bc8ae885e26ab372abb141163" alt="快速选择元素"
用XPath表达式选择DOM
XPath is a query language for selecting nodes from documents and generally returns a node-set, string, boolean or number. You can use XPath expressions to query the DOM from the DevTools JavaScript console.
The $x(xpath) command will allow you to execute a query - see below for an example of how to search for the images in a page using $x('//img'):
data:image/s3,"s3://crabby-images/b0218/b0218b93dcf700038a36e0ea92204d4e688748e8" alt="利用XPath选择元素"
However, the function also accepts an optional second argument for the path context - i.e $x(xpath, context). This lets us select a specific context (e.g an iframe) and run an XPath query against it.
var frame = document.getElementsByTagName('iframe')[0].contentWindow.document.body;
$x('//'img, frame);
which queries the images within the specified iframe.
得到控制台最后一个输出的结果
使用 $_
得到控制台最后一个输出的结果.
data:image/s3,"s3://crabby-images/cc13c/cc13c2f0d005d11f2dff8812aa0d7971d46ed000" alt="得到控制台最后一个输出的结果"
console.dir()
console.dir(object) 提供的命令可以列出一个JavaScript对象所有属性。
data:image/s3,"s3://crabby-images/5692d/5692d4f029f49793bd7a6bb98013041e77b39890" alt="console.dir()"
在指定的 iframe 中运行控制台中命令
Along the bottom bar of the DevTools are drop-down options that change depending on the context of your current tab. When you’re in the Console panel, there’s a drop-down that allows you to select the frame context that the console will operate in. Select your frame in the drop-down and you’ll find yourself in the right context in no time.
data:image/s3,"s3://crabby-images/46efe/46efe0d7de538b67ae72818a8906836207dae819" alt="在指定的 iframe 中运行控制台中命"
当浏览器切换到另一个页面时保存控制台中历史
在控制台版面右键,选择 save
即可
data:image/s3,"s3://crabby-images/66f12/66f129535be48daf18d8f191b1ad850042bf681b" alt="保存控制台的历史"
console.time() 和 console.timeEnd()
可以 console.time()
和 console.timeEnd()
计算程序运行的时间.如下:
data:image/s3,"s3://crabby-images/15036/15036919d21b1dd92021cde647a4e9ebba35ad0f" alt="console.time() 和 console.timeEnd()"
console.profile() 和 console.profileEnd()
DevTools打开时,调用 console.profile()
JavaScript CPU的分析。console.profileEnd()
结束此次分析。如下:
data:image/s3,"s3://crabby-images/a3cbc/a3cbc4db39d57254a4c2cb6dbbaccf697f956206" alt="console.profile() 和 console.profileEnd()"
每次分析都被加到 Profiles
面板和 `console.profilses'中:
data:image/s3,"s3://crabby-images/2916d/2916d9acdb31216d1e6410d972ad0464b7ecb62c" alt="console.profile() 和 console.profileEnd()"
data:image/s3,"s3://crabby-images/d9561/d95615a76fa7c641a67f33cc807dd7db6f9ffc7d" alt="console.profile() 和 console.profileEnd()"
** 更多使用控制台的技巧见using the console**:
data:image/s3,"s3://crabby-images/81a07/81a07baeec1e8ea2b40aecf99ecb75255ae24135" alt="using the console"
Elements
打开尺标线
打开 Devtools Settings
> General
> Show rulers
即可
data:image/s3,"s3://crabby-images/1bb98/1bb98c1e1a153327bbe156e59bc7e70f8ac6d2e0" alt="Show rulers"
css 属性的自动补全
data:image/s3,"s3://crabby-images/c6bf2/c6bf24c335be362ce3130f1a35b0f3c98883ba95" alt="css"
data:image/s3,"s3://crabby-images/4c3a6/4c3a6204359503ab94ff0232e8c3dacf70d2efe9" alt="css"
data:image/s3,"s3://crabby-images/7d29f/7d29fcb4779597ad016bfd4282d679d800e41392" alt="css"
颜色选择器
在Devtools中点击颜色时可以调出一个颜色选择器。用 shift
+ 'click' 可以改变颜色的样式。
data:image/s3,"s3://crabby-images/05665/05665a856acd4b599e1cde7402a9fd0e19f921b7" alt="css"
新增CSS 样式
在Elements面板中拖曳元素
在Elements中拖曳元素可以改变该元素在文档流中的未知和显示的样式。
data:image/s3,"s3://crabby-images/b870e/b870ee28a6970c1ec0d808d2505e56baee03cc11" alt="在Elements面板中拖曳元素"
改变元素的状态
- Right click on a child element and select 'Inspect Element'
- In the Elements panel right-click the parent element and choose "Force Element State"
- You can now choose one of :active, :hover, :focus or :visited to force the element into one of these states.
data:image/s3,"s3://crabby-images/2a4ba/2a4baf07847662bcdf40e1ce206fcae8a658bea5" alt="改变元素的状态"
调试 less 或者 sass 代码
Settings
> General
> Sources
> Enable CSS source maps
data:image/s3,"s3://crabby-images/e6083/e6083da06ae29d4f0739779a3d5eac864ab4ef2d" alt="enable source"
** 更多关于样式和DOM操作的技巧Editing Styles And The DOM**
data:image/s3,"s3://crabby-images/80142/801424ecc9eeb2b8a559b007f786983498531c96" alt="dom and styles"