文档章节

带你制作百词斩单词表读写插件

白志华
 白志华
发布于 2015/10/18 10:57
字数 1105
阅读 49
收藏 0

精选30+云产品,助力企业轻松上云!>>>

       上篇博文简单的介绍了一下Chrome插件,今天就与大家分享一下我做的这款有实际意义的插件吧。


       做这款插件主要是用百词斩网站进行单词学习时,遇到的一点点闹心事儿。在单词表中不能听发音,也不能练习拼写,所以才忍无可忍的做了这么一款插件。自我感觉还是很不错的。


      先来看看效果吧:


(原网站格式)


(安装插件后,多了一个按钮)


(点击change model后的效果,可显隐单词,可听发音,可检测拼写,看动画效果


       做这个插件,主要应用了content script与页面进行交互的。manifest.json内容如下:

{
    "name": "百词斩测试插件",
    "version": "1.0.0.0",
    "manifest_version": 2,
    "background": {
      "page": "background.html"
    },
    "permissions": [
      "http://*/"
    ],
    "icons": {"16":"images/icon_16.png","128":"images/icon_128.png"},
    "description": "百词斩测试插件,信息技术提高班 八期 龙轩出品",
    "content_scripts": [{
      "all_frames": true,
      "matches": ["http://www.baicizhan.com/user/words/list*"],
      "js": ["js/jquery-1.7.2.min.js","js/content_script.js","js/background.js"]
    }]
}

       最关键的就是content_script节点,其中所有的功能都是用js在后台完成的。而matches则是设置匹配模式,规定遇到哪些页面会自动执行代码。其他的就比较简单了,直接写jquery命令即可,如修改页面宽度:

//修改css样式
function csschange(){
  $(".user-word-list-block").css("width","1000px");
  $(".w950").css("margin-left","175px");
}

       其中有点难度的就是往页面注入js代码,我用jquery尝试了N多次,都不能成功,插进去的js都是文本状态,不能执行。终于使用原生的js操作成功了,代码如下:

function fun1(){//....}
function fun2(){//....}

//将js代码加入到页面的head节点中
function addscript(prefix,f,suffix){
  var script = document.createElement("script");
  script.type="text/javascript";
  script.innerHTML=prefix+eval(f)+suffix; 
  document.head.appendChild(script);
}

//注入fun1函数
addscript("",fun1,"");

//注入fun2函数,并自启动
addscript("(",fun2,")();");

       当然也直接设置控件的事件为function的对象,当然也需要用原生js写:

function fun1(){//...}

//往指定节点中添加a标签,并设置onclick对象
function addLable_A(name, fun,node) {
  var a = document.createElement("a");
  a.innerText = name;
  a.href="#";
  a.onclick = fun;
  node.appendChild(a);
}

//向class为btn-start-review的第一个元素中插入a标签,并设定onclick事件
addLable_A("Change Model",fun1,document.getElementsByClassName("btn-start-review")[0])

       添加这些都是小事儿,主要是分析单词发音的网址。由于手头没有可用的http抓包分析工具,所以点击了n多次,然后用谷歌的开发工具挨个分析请求,并通过n多实验,终于可以拿到所有的单词详细记录,包括解释、音标、例句、例句中单词信息、图片以及单词和句子的音频地址。但是都拿到的话会花费很长时间。不过看到单词发音是有规律的,所以只做了发音的链接。音频地址规则为:

http://baicizhan0.qiniudn.com/word_audios/+单词+.mp3

       音频地址可以拼出来,但是却没有一个可以播放的,在网上找了一些代码,却发现Chrome上不能播放,但是ie就没有问题(提示有activex控件,可能需要media player才行)。但是百词斩本身在chrome上是可以播放的,所以经过几番周折,终于分析出它自己写了一个soundmanager来完成播放操作,我直接把newsoundmanager的方法那过来直接加载进来就可以用了,调用create创建,play播放,destroy销毁。代码如下:

//生成音乐播放器
function t() {
    1 != window.isSoundManagerLoading && 1 != window.isSoundManagerLoaded && (window.isSoundManagerLoading = !0, window.SM2_DEFER = !0, $.cachedScript("http://assets1.baicizhan.com/pack/soundmanager2-nodebug-jsmin.js").done(function() {
        window.soundManager = new SoundManager;
        var t = {url: "/sound_manager/",debugMode: !1,debugFlash: !1,useFlashBlock: !1,useHighPerformance: !0,noSWFCache: !0,onready: function() {
                window.isSoundManagerLoaded = !0, window.isSoundManagerLoading = !1
            }};
        navigator.userAgent.toLowerCase().match(/(iphone|ipod|ipad)/) && (t.preferFlash = !1), soundManager.setup(t), soundManager.beginDelayedInit()
    }))
}

//播放单词读音
function wordvoiceplay(field){

    var file="http://baicizhan0.qiniudn.com/word_audios/"+field+".mp3";
  //创建音乐播放
  soundManager.createSound({id: 'word-audio-'+field,url:file,autoPlay: !1,autoLoad: !1}).play();
  
  //设置1秒后自动销毁音频对象
  setTimeout(function(){soundManager.destroySound('word-audio'+field);},1000);
}

       在制作的过程中,主要遇到了这么几个小问题,主要借鉴了自称非官方的文档360chrome插件开发文档。也参照了一些例子,感觉很不错。去这里可以下载到。


       做出来以后,发现插件的确很不错,可以自由扩展,属于本地个性化设计,值得学习一下。


版权声明:本文为博主原创文章,未经博主允许不得转载。

白志华
粉丝 34
博文 265
码字总数 57524
作品 0
长沙
程序员
私信 提问
加载中
请先登录后再评论。
如何选择背单词应用?

理想中的背单词应用如下 首先请参考知乎上青格乐的答案 链接:https://www.zhihu.com/question/26649929 来源:知乎 作者:青格乐 著作权归作者所有。商业转载请联系作者获得授权,非商业转载...

很小的小小鱼儿
2016/03/08
0
0
第6周小组作业:软件测试和评估

一、计划说明   a.本组选择的对比测试产品扇贝单词和百词斩;   b.测试进度表: 项目 内容说明 预计耗时(分钟) 实际耗时(分钟) Planning 计划 60 45 ·Estimate ·估计这个任务需要多...

osc_x4rg8g6r
2018/04/23
1
0
百词斩与不背单词APP测试分析

1 基本任务 1.1 待测产品介绍 百词斩:百词斩是针对英语学习开发的一款“图背单词软件”。软件为每一个单词提供了趣味的配图和例句,让记单词成为一种乐趣。 百词斩覆盖了从初高中、四六级、...

osc_x4rg8g6r
2018/04/23
5
0
怎样背单词才算正确的姿势?

1. 一个单词你背了8遍,还是没记住,说明你是正常人,请坚信重复的力量。联想法、谐音法、记忆宫殿法、词根词缀法,作用都是有限的,不能代替多次重复,用大量阅读的方式来增加词汇量其实也是...

很小的小小鱼儿
2016/03/08
0
0
百词斩Java程序员面试11个问题,你会几个?2018-04-10

近日,我们在w3cschool app开发者头条上,可以看到百词斩Java程序员面经。 在分享百词斩Java面经前,w3cschool特别给程序员小伙伴们带来一些Java学习干货: 0、学习Java必备的3大神器 如果你...

W3Cschool
2018/04/10
0
0

没有更多内容

加载失败,请刷新页面

加载更多

1Mn18Cr18N无磁护环强度高

1Mn18Cr18N高氮奥氏体不锈钢具有强韧性好、耐蚀性好、无磁等诸多优点,成为核主泵飞轮保持环材料的选择。 保持环的热套工序要求保持环材料具备优良的热膨胀性能,飞轮保持环完整性的保证要求...

无磁钢
18分钟前
10
0
比较器,Comparator与Comparable

Comparable比较器 从JDK1.2后提供了比较器的接口:Comparable接口。 public interface Comparable<T>{ /** * 实现对象的比较处理操作 * @param o 要比较的对象 * @return...

哼着我的小调调
30分钟前
9
0
以每种语言编译时,在C和C ++中都有效的代码能否产生不同的行为?

问题: C and C++ have many differences, and not all valid C code is valid C++ code. C和C ++有很多区别,并非所有有效的C代码都是有效的C ++代码。 (By "valid" I mean standard code w......

富含淀粉
35分钟前
7
0
使用getApplication()作为上下文的对话框抛出“无法添加窗口-令牌null不适用于应用程序”

问题: My Activity is trying to create an AlertDialog which requires a Context as a parameter. 我的活动试图创建一个AlertContext,它需要一个Context作为参数。 This works as expect......

法国红酒甜
今天
13
0
亚马逊测评买家号多开_可以解决这个问题嘛?_微信公众号: VMlogin中文版

对于很多亚马逊卖家来说,做亚马逊测评是并不可少的,都在为了自己的店铺能够获得更多的销售,着重培养自己产品的各项属性,以求获得一个更好的权重排名从而获得更多的曝光,但是在旺季期间亚...

竹节猫-ASOer
今天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部