我的第一个chrome扩展(2)——基本知识
1.manifest介绍界面:json格式
json:JavaScript Object Notation
包括两种结构:
key:value对:{{"A1":"value1","A2":"value2","A3":"value3"},{…},{…}}
值的有序集合 {"books":["book1","book2","book3"]}
value类型:字符串,数字,对象,数组,bool类型和null中的一种
json格式的数据可嵌套
2.DOM:document object model
DOM参阅:
http://www.ituring.com.cn/article/60188
http://www.w3school.com.cn/htmldom/
分为核心DOM,XML DOM和HTML DOM
HTML DOM的树状结构图:
每个文件有一个根元素<html>
每个根元素有两个子元素<head><body>
标签必须成对出现或者是自闭标签,嵌套关系必须明确
标签可以包含一些属性或者子节点,子节点可以是元素也可以是文本,如:
<img src="data:images/dog.png" />
<div>Hello World!</div><input type="text" id="stu_name" value="Billy" />
上面的input有type,id和value三个属性
type="text"表示是文本输出框
id="stu_name"表明给这个元素分配了一个名为stu_name的id
value="Billy"表示输入框的默认值为Billy
不同元素往往拥有不同的属性名,比如对于img元素,通常会包含src属性以指定所显示图片的地址,而input元素往往会包含type属性来描述输入框的类型。
js中有多种获取DOM元素的方法:
getElementById:通过id获取元素(HTML中元素的id唯一)
getElementsByName:通过name获取元素
getElementsByTagName:通过标签名获取元素
getElementsByClass:通过类名获取元素
后三种获得的是一个包含一个或多个元素的数组(必须是数组)
getAttribute:读取元素属性
setAttribute:添加或更改元素属性
removeAttribute:删除元素属性
var imgurl = document.getElementById('my_image').src;
document.getElementById('my_another_image').src = imgurl;
CSS的选择器:tagName,.className,#id
p {
width: 200px; //p标签的宽度为200px
}
.postlist {
width: 150px; //postlist类的元素宽为150px
}
#footer {
width: 100px; //id为footer的元素宽度为100px
}
CSS选择器还可以通过元素属性进行定位
input[type="text"]{
font-size:16px;
} //作用于所有文本输入框
3.跨域请求:通过XMLHttpRequest请求数据时禁止跨域
需要在Manifest的permissions属性中声明需要的权限
注意:阻塞函数与非阻塞函数
大多数API调用为非阻塞函数,因此要用回调函数传递结果
如:function httpRequest(url,callback)(url为传入网址,callback为处理传回数据的函数)
问题:传回的数据安全起见不能直接用innerHTML插入或eval执行
若将数据写入:使用innerText
若是json格式的数据:使用JSON.parse解析 ?
结合try-catch判定数据的格式 ?
4.常驻后台
注意:js的格式:函数除定义外,调用时记得加;
加入background域即可
我的第一个chrome扩展(2)——基本知识的更多相关文章
- 我的第一个chrome扩展(1)——读样例,实现时钟
学习chrome扩展开发: 与网页类似,需要的知识:html,javascript chrome扩展程序的构成: manifest.json:对扩展程序的整体描述文件 { "manifest ...
- 如何用原生js开发一个Chrome扩展程序
原文地址:How to Build a Simple Chrome Extension in Vanilla JavaScript 开发一个Chrome扩展程序非常简单,只需要使用原生的js就可以完成 ...
- 如何通过写一个chrome扩展启动本地程序
@(编程) [toc] 本文介绍如何利用Chrome 的插件, 从我们的一个网站中启动一个我们的本地程序.本文的环境是windows10,本文的例子是通过点击网页上的一个button,调用本地的wor ...
- 如何开发一个chrome扩展
chrome是一个不错的浏览器,web开发者工作中一般都会使用chrome做为默认浏览器,它有很多扩展,给浏览器补充了各种功能,增强了用户体验.chrome具体能干什么?怎么做出来的呢? chrome ...
- 推荐一个Chrome扩展应用,能够自动去除CSDN广告
作为一个程序员,每天编程遇到问题时,少不了前往国内著名的CSDN网站上查信息,看是否有同行遇到类似问题.很多时候根据遇到问题的错误消息进行搜索,结果都是一篇篇CSDN博客.这些博客打开后都会显示很多广 ...
- 跟我一起写一个chrome扩展程序
在我没有看这本书之前,我都想象不到,原来chrome扩展程序可以这样写,真的非常有意思. 就是用最简单最基础的代码,然后就实现了一些非常有意思的玩意儿. 先看效果图 实际运用要和现实联系在一起,经历和 ...
- 自己写一个chrome扩展程序 - 右键菜单扩展
最近在学习Spring,心想dotnet如何实现类似形式呢.于是想认真学习Casetle组件,发现没有书籍!而spring的书多得很.于是只好找网上教程了.发现系统的文章不多.Terrylee好多文章 ...
- 我的第一个chrome扩展(0)——目标
当前有两个方向: 一.实现一个自动解码的地址栏监视器 扩展程序在后台不断监视地址栏输入,地址栏输入并回车后检查输入,若输入符合解码条件则调用网站信息进行解码,并将结果输出到地址栏,否则不改变: 初始阶 ...
- 我的第一个chrome扩展(3)——继续读样例
1.操作用户正在浏览的界面 http://www.ituring.com.cn/article/60212 问题:1.google未定义ID,用name为何无法找到? 2.如何让整个按钮一起动?原函数 ...
随机推荐
- mysql数据库版本引发的问题
改前: 改后:
- 【转】reduce端缓存数据过多出现FGC,导致reduce生成的数据无法写到hdfs
转自 http://blog.csdn.net/bigdatahappy/article/details/41726389 转这个目的,是因为该贴子中调优思路不错,值得学习 搜索推荐有一个job,1 ...
- BZOJ1444 : [Jsoi2009]有趣的游戏
建立AC自动机,并求出转移矩阵. 再用$\sum E(终止节点)=1$去替换第一个方程,高斯消元即可. 时间复杂度$O(n^3l^3)$. 注意精度问题,要特判0.00的情况. #include< ...
- BZOJ3075 : [Usaco2013]Necklace
首先对b串做kmp求出nxt数组. 设f[i][j]表示考虑了a的前i个字符,在b中匹配到了j的最长长度,按照kmp算法直接转移即可. $ans=n-\max(f[n][j])$. 时间复杂度$O(n ...
- 【BZOJ】1040: [ZJOI2008]骑士(环套树dp)
http://www.lydsy.com/JudgeOnline/problem.php?id=1040 简直不能再神的题orz. 蒟蒻即使蒟蒻,完全不会. 一开始看到数据n<=1000000就 ...
- C#关闭word进程
C#关闭word进程 foreach (System.Diagnostics.Process p in System.Diagnostics.Process.GetProcessesByName(&q ...
- Maya Shortcuts 常用快捷键
快捷键 功能解释 工具操作 enter 完成当前操作 ~ 终止当前操作 insert 插入工具编辑模式 w 移动工具 e 旋转工具 r 缩放工具 y 非固定排布工具 shift+Q 选择工具,(切换到 ...
- Useful Qt Examples
Canvas API Basic Layouts Camera Example Video Widget Example Image Viewer Example Part 6 - Loading a ...
- [百科] - iLBC
iLBC是一种专为包交换网络通信设计的编解码,优于目前流行的G.729.G.723.1,对丢包进行了特有处理,即使在丢包率相当高的网络环境下,仍可获得非常清晰的语音效果. 30ms ptime的iLB ...
- js将日期格式转换为YYYY-MM-DD HH:MM:SS
<script language="javascript" type="text/javascript"> //页面加载 jQuery(docume ...