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)——基本知识的更多相关文章

  1. 我的第一个chrome扩展(1)——读样例,实现时钟

    学习chrome扩展开发: 与网页类似,需要的知识:html,javascript chrome扩展程序的构成: manifest.json:对扩展程序的整体描述文件 { "manifest ...

  2. 如何用原生js开发一个Chrome扩展程序

    原文地址:How to Build a Simple Chrome Extension in Vanilla JavaScript 开发一个Chrome扩展程序非常简单,只需要使用原生的js就可以完成 ...

  3. 如何通过写一个chrome扩展启动本地程序

    @(编程) [toc] 本文介绍如何利用Chrome 的插件, 从我们的一个网站中启动一个我们的本地程序.本文的环境是windows10,本文的例子是通过点击网页上的一个button,调用本地的wor ...

  4. 如何开发一个chrome扩展

    chrome是一个不错的浏览器,web开发者工作中一般都会使用chrome做为默认浏览器,它有很多扩展,给浏览器补充了各种功能,增强了用户体验.chrome具体能干什么?怎么做出来的呢? chrome ...

  5. 推荐一个Chrome扩展应用,能够自动去除CSDN广告

    作为一个程序员,每天编程遇到问题时,少不了前往国内著名的CSDN网站上查信息,看是否有同行遇到类似问题.很多时候根据遇到问题的错误消息进行搜索,结果都是一篇篇CSDN博客.这些博客打开后都会显示很多广 ...

  6. 跟我一起写一个chrome扩展程序

    在我没有看这本书之前,我都想象不到,原来chrome扩展程序可以这样写,真的非常有意思. 就是用最简单最基础的代码,然后就实现了一些非常有意思的玩意儿. 先看效果图 实际运用要和现实联系在一起,经历和 ...

  7. 自己写一个chrome扩展程序 - 右键菜单扩展

    最近在学习Spring,心想dotnet如何实现类似形式呢.于是想认真学习Casetle组件,发现没有书籍!而spring的书多得很.于是只好找网上教程了.发现系统的文章不多.Terrylee好多文章 ...

  8. 我的第一个chrome扩展(0)——目标

    当前有两个方向: 一.实现一个自动解码的地址栏监视器 扩展程序在后台不断监视地址栏输入,地址栏输入并回车后检查输入,若输入符合解码条件则调用网站信息进行解码,并将结果输出到地址栏,否则不改变: 初始阶 ...

  9. 我的第一个chrome扩展(3)——继续读样例

    1.操作用户正在浏览的界面 http://www.ituring.com.cn/article/60212 问题:1.google未定义ID,用name为何无法找到? 2.如何让整个按钮一起动?原函数 ...

随机推荐

  1. 关于Scala JDK与IDEA版本兼容的问题

    文章来自:http://www.cnblogs.com/hark0623/p/4174652.html  转发请注明 我刚装上Scala和IDEA时发现运行代码后总是出现 xxx is already ...

  2. 安装Kali Linux操作系统Kali Linux无线网络渗透

    安装Kali Linux操作系统Kali Linux无线网络渗透 Kali Linux是一个基于Debian的Linux发行版,它的前身是BackTrack Linux发行版.在该操作系统中,自带了大 ...

  3. bug记录

    1>-[DYMessageNewsTableView _contentOffsetForScrollingToRowAtIndexPath:atScrollPosition:]: row (37 ...

  4. bzoj1019 [SHOI2008]汉诺塔

    1019: [SHOI2008]汉诺塔 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 1030  Solved: 638[Submit][Status] ...

  5. BZOJ4346 : [POI2016]Nadajniki

    设$f[x][j]$表示$x$点不放无线,它的儿子里放了$j$个无线,且对$x$的父亲不作要求时的最小代价. $g[x][j]$表示$x$点不放无线,要求$x$的父亲至少放$j$个无线时的最小代价. ...

  6. POJ 3352 (边双连通分量)

    题目链接: http://poj.org/problem?id=3352 题目大意:一个连通图中,至少添加多少条边,使得删除任意一条边之后,图还是连通的. 解题思路: 首先来看下边双连通分量的定义: ...

  7. 不通过App Store,在iOS设备上直接安装应用程序(转)

    今天在iOS设备上安装天翼云存储app,在safari上直接打开http://cloud.189.cn/wap/index.jsp,点击“点击免费安装”,如下图: 神奇的事情发生了,设备上直接下载ap ...

  8. topcoder 594 DIV2 foxandclassroom

    暴力枚举 1 #include <iostream> #include <vector> #include <string> using namespace std ...

  9. HDU 4417 Super Mario(划分树+二分)

    题目链接 #include <cstdio> #include <cstring> #include <algorithm> using namespace std ...

  10. Javascript刷新页面大全

    非模态刷新父页面:window.opener.location.reload(); 模态刷新父页面:window.dialogArguments.location.reload(); 先来看一个简单的 ...