谷歌Chrome浏览器扩展程序开发小记_javascript技巧

  根据公司的规定,每月八小时,弹性工作制。所以大家平时来的不太准时,如果有事,下班也就早些回去了。所以一个月下来工作时间可能不够,但是公司的考勤日历是这样的:

除了请假和法定节假日外,其他样式显示都是一样的,每次都要一个个估算这个月的大概工作时间,十分不方便。后来看到公司有人在用一个Chrome扩展程序,可以计算出一个月的工作时间,但是我觉得还是没有看到我想看的东西,因为除了每个月的累计工作时间外,我还想看到:平均每天工作时长、每一天的工作时长、20点以后的天数(20点以后下班的可以报销晚饭的,哈哈……)、22点以后下班的天数(报销打车费)……所以我决定还是自己写一个吧。

  第一步,我先写了一个JS方法,然后通过F12开发者工具的Console复制粘贴运行。

  公司用的OA系统没有引用jQuery库,所以我刚开始的想法是想动态引用jQuery类库,如下:

复制代码 代码如下:

var script = document.createElement("script");
script.src = "http://ajax.googleapis.com/ajax/libs/jquery/1.5.2/jquery.min.js";
document.body.appendChild(script);

但是遇到了问题:一个是$被占用,二是HR系统采用iframe嵌套,并且还有frame嵌套,结构很复杂。而console运行的代码是在最顶层运行的,后期的chrome扩展插件是运行在内部frame中的,可能这里的JS后面不能直接使用。虽然$被占用的问题可以通过jQuery.noConflict();来解决,但是jquery库和原来系统的JS库存在调用顺序的问题,而且在内部的frame中死活访问不到jQuery这个对象。最后我决定放弃使用jQuery,该用原生JavaScript。

JS代码如下:

/*
 * author:清明雨上
 * date:2016-1-5
 */
var mydate = function() {
  //time2-time1
  function getTimeDiff(time1, time2) {
    var st1 = time1.split(':');
    var st2 = time2.split(':');
    return ((st2[0] | 0) * 60 + (st2[1] | 0)) - ((st1[0] | 0) * 60 + (st1[1] | 0) * 1);
  }

  var timeList = [];
  var mymain = window.parent.frames['Main'].document.getElementById('ctl00_cphMain_CalendarAC');
  var listAC = mymain.getElementsByClassName('listAC');
  for (var i = 0; i < listAC.length; i++) {
    var item = listAC[i];
    var t = {};
    t.timeSpan = item.getElementsByTagName('td')[1].innerText;
    t.remark = item.getElementsByTagName('td')[2].innerText;
    timeList.push(t);
  };

  var totalMin = 0;
  var noworkDays = 0; //请假天数
  var workDays = 0; //实际上班天数
  var workHourEveryday = [];
  var no8h = 0; //未满8小时天数
  var over20 = 0; //20点以后下班天数
  var over21 = 0; //21点以后下班天数
  var over22 = 0; //22点以后下班天数
  var over23 = 0; //23点以后下班天数
  for (var i = 0; i < timeList.length; i++) {
    var time = timeList[i];
    if (time.remark != '无') {
      noworkDays++;
      continue;
    }
    if (time.timeSpan == '无刷卡记录')
      continue;

    var splitTime = time.timeSpan.split('~');
    if (splitTime.length == 2) {
      //正常上下班
      var begin = splitTime[0];
      var end = splitTime[1];
      var thisMin = getTimeDiff(begin, end);
      totalMin += thisMin;
      workDays++;
      if (thisMin / 60 < 8) {
        workHourEveryday.push('<font color="red"><b style="font-size:15px">' + parseInt(thisMin / 60) + '</b>.' + thisMin % 60 + '</font>');
        no8h++;
      } else {
        workHourEveryday.push('<b style="font-size:15px">' + parseInt(thisMin / 60) + '</b>.' + thisMin % 60);
        var offworkHour = parseInt(end.split(':')[0]);
        if (offworkHour >= 20) {
          over20++;
        }
        if (offworkHour >= 21) {
          over21++;
        }
        if (offworkHour >= 22) {
          over22++;
        }
        if (offworkHour >= 23) {
          over23++;
        }
      }
    }
  };
  var myHour = parseInt(totalMin / 60); //本月工作累计小时数
  var otherMin = totalMin % 60; //本月工作出小时部分外的分钟数
  var avgHourOneDay = workDays == 0 ? '0.0' : '<b style="font-size:15px">'+(parseInt(myHour / workDays) + '</b>.' + (parseInt((myHour % workDays) * 60 / workDays) + parseInt(otherMin / workDays))); //平均每天工作时长

  var html = '<div class="alectest" style="background: #cbebfb;padding:7px;">\
        <div>出勤时间:<b style="font-size:15px;color:red">' + myHour + '</b>小时<font color="red">' + otherMin + '</font>分钟(平均<font color="red">' + avgHourOneDay + '</font>小时/天)</div>\
        <div>参考时间:' + workDays * 8 + '小时【' + workDays + '天】(除去请假和节假日,实际有打卡记录的天数)</div>\
        <div>请假/外出天数:' + noworkDays + '天</div>\
        <div>每天工作时间(格式:小时.分钟):' + workHourEveryday.join(',') + '</div>\
        <div>未满8小时天数:<b style="font-size:15px">' + no8h + '</b>天</div>\
        <div>20点以后下班天数:<b style="font-size:15px">' + over20 + '</b>天</div>\
        <div>21点以后下班天数:<b style="font-size:15px">' + over21 + '</b>天</div>\
        <div>22点以后下班天数:<b style="font-size:15px">' + over22 + '</b>天</div>\
        <div>23点以后下班天数:<b style="font-size:15px">' + over23 + '</b>天</div>\
       </div>'
  var alectest = mymain.parentNode.getElementsByClassName('alectest');
  if (alectest.length > 0) {
    // mymain.parentNode.removeChild(alectest[0]);
    alectest[0].innerHTML = html;
  } else {
    var div = document.createElement("div");
    div.innerHTML = html;
    var fragement = document.createDocumentFragment();
    while (div.childNodes[0]) {
      fragement.appendChild(div.childNodes[0]);
    }
    mymain.parentNode.insertBefore(fragement, mymain);
  }
  bindBtnClick();
}
var bindBtnClick = function() {
  window.parent.frames['Main'].document.getElementById('ctl00_cphTop_BtnQuery').addEventListener('click', function() {
    var inter = setInterval(function() {
      if (window.parent.frames['Main'].document.getElementById('ctl00_cphMain_CalendarAC') &&
        window.parent.frames['Main'].document.getElementById('ctl00_UpMaster').style.display == 'none') {
        clearInterval(inter);
        mydate();
      }
    }, 500);
  }, false);
}
bindBtnClick();

代码说明:监听考勤查询按钮的click事件,考勤信息加载完成后,执行我的JS方法。

  第二步,开发Chrome扩展程序

  参考资料:http://open.chrome.360.cn/extension_dev/content_scripts.html(查询manifest.json的content_scripts节点的各个属性说明)

  manifest.json是必须的,最终内容如下:

{
 "manifest_version":2,
  "name": "Extension Name",
 "version": "0.1.0",
 "description": "插件描述",
 "icons": { "48": "icon.png" },
 "content_scripts": [
  {
   "all_frames" : true,
   "matches": ["http://*"],
   "js": ["haha.js"],
   "run_at": "document_end"
  }
 ]
}

另外,在同目录下放入一个icon.png图片,至此,所有文件都准备完毕,目录如下:

打开Chrome的扩展程序列表的开发者模式》大包扩展程序...,在扩展程序根目录中输入上面三个文件所在的父目录。

点击【打包扩展程序】即可。

说明:如果点击该按钮长时间未能反映,可以能是你的chrome不允许第三方非认证的扩展程序,解决方案是,点击chrome快捷方式右键》属性》目标输入框后面追加“ enable-easy-off-store-extension-install”,注意前面的空格。

然后再尝试以上步骤就行了。

  第三步,防止Chrome屏蔽非官方扩展程序 设置

  Chrome会提示暂停非官方扩展程序,每次启动就有提示,很烦人。

  查找资料:http://www.itechzero.com/prevent-chrome-shielding-unofficial-extensions-tutorial.html(防止Chrome屏蔽非官方扩展程序教程)

根据以上资料说明,可以轻松解决这个问题。

  

  至此,该可扩展程序全部完成,结果图如下:

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索chrome
浏览器扩展开发
chrome浏览器扩展程序、chrome浏览器扩展、chrome浏览器扩展商店、谷歌浏览器javascript、谷歌chrome浏览器,以便于您获取更多的相关知识。

时间: 2024-11-10 07:09:42

谷歌Chrome浏览器扩展程序开发小记_javascript技巧的相关文章

JavaScript开发Chrome浏览器扩展程序UI的教程_javascript技巧

基本知识 1.插件文件结构 1.1.manifest.json每一个扩展.可安装的WebApp.皮肤,都有一个JSON格式的manifest文件,里面存放重要的插件相关信息. 一个最基本的配置例子: { "name": "browser action demo", "version": "1.0", "permissions": [ "tabs", "http://*/*&qu

chrome扩展程序开发之在目标页面运行自己的JS

大家都知道JS是运行在客户端的,所以,如果我们自己写一个浏览器的话,是一定可以往下载下来的网页源代码中加入js的.可惜我们没有这个能力.不过幸运的是,chrome的扩展程序可以帮我们做到这件事. 本文会做一个chrome插件开发的入门介绍,实现利用chrome扩展实现在目标网页运行我们的js的功能.关于chrome扩展的详细内容,可以通过官网了解. 开发工具很简单,记事本就OK了,当然还要有一个chrome浏览器. 新建一个文件夹,比如,HelloWorld 然后创建一个文本文件,作为这个扩展程

谷歌将阻止用户被引诱安装Chrome浏览器扩展

谷歌 Chrome 浏览器有一个名为"inline install"的方便功能,让用户直接从开发者网站上安装扩展,而无需去谷歌网上商店安装 Chrome 浏览器扩展.不幸的是,此项功能已经被攻击者滥用,他们以提供软件更新为名来诱骗用户安装一个恶意扩展,以显示付费广告.对此,谷歌表示它正在努力结束对这种功能的滥用问题. 谷歌已经停止不通过网上商店来安装浏览器扩展的功能.如果谷歌检测到一个广告试图安装Chrome浏览器扩展,它会禁用内嵌安装,并迫使它们重定向到Chrome网上应用商店,来先

如何在360极速浏览器安装谷歌Chrome浏览器插件

  如何在360极速浏览器安装谷歌Chrome浏览器插件         1.我们可以从网上下载一些需要的Chrome浏览器插件(一般为zip格式),并解压; 2.解压后如果目录下有一个crx格式的文件则双击打开; 3.接着会跳转到360极速浏览器插件安装界面,点击"添加"即可完成安装; 4.如果解压后的目录是含有几个文件夹和文件则通过下面的方法进行安装; 5.打开360极速浏览器右上角的菜单,点击"选项"; 6.然后点击左下角的"扩展程序";

谷歌Chrome浏览器10大最有用插件推荐

浏览器作为互联网重要的入口,越来越受到人们的重视.而一款好的浏览器,除了可以浏览网页之外,还应该是个"全能选手".正如谷歌的Chrome浏览器,其最大的魅力就在于可以安装各种扩展插件,让Chrome浏览器自身的功能更加丰富.在Google Chrome网上应用店,用户可以下载和安装应用程序.扩展程序以及主题背景.那么,在成千上万款程序和扩展中,到底都有些什么?哪些最有用? 谷歌Chrome浏览器十大最有用插件推荐         下一页更精彩

谷歌chrome浏览器在win10预览版10525无法打开网页怎么办

  谷歌chrome浏览器在win10预览版10525无法打开网页怎么办?在微软推送Win10预览版10525之后,很多升级到该版本的用户发现自己的谷歌Chrome浏览器无法正常打开网页,只出现一个灰白色页面,并给出如下提示:Aw,Snap!在显示此页面时出现了问题.关闭你不需要的应用和选项卡,可能会对节省内存有帮助. 从这些提示语可以看出,打不开页面的原因是内存不够.但出现问题的用户并没有在很极端的内存下浏览网页,完全是和平时一样. 据悉,该问题的出现貌似和安装的扩展程序以及Chrome浏览器

基于SharpMap扩展程序开发实例

SharpMap是基于.Net平台开发的GIS地图渲染组件.在SharpMap的内部设计了基于OGC 标准的几何模型 构架,设计了IProvider策略模式的多源矢量地图数据适配器接口,地图要素渲染的底层主要通过几何变 换将Geometry转换为.Net支持的几何模型如System.Drawing.Point.System.Drawing.Rectangle. System.Drawing.Drawing2D.GraphicsPath等,然后调用System.Drawing.Graphics类的

谷歌chrome浏览器如何在后台运行

  有时候我们电脑运行速度没那么快了,随便打开一个程序都卡个半天,特别是打开浏览器这种占用资源多的程序,各加是一卡再卡.今天小编为读者带来如何让谷歌浏览器(google chrome)在后台运行,加速打开浏览器的速度,提高我们浏览网页的效率. 让谷歌chrome浏览器在后台运行的方法 1.打开谷歌浏览器(google chrome),点击小编红框标记位置,点击设置: 2.用鼠标下滑到最底部,点击显示高级设置: 3.继续滚动鼠标到最底部,勾选"关闭google chrome后继续运行后台应用&qu

谷歌chrome浏览器怎么滚动截图

我们使用的谷歌chrome浏览器怎么滚动截图?很多小伙伴们都想知道截图在哪,帮助自己来截图完成工作.那么格子啦小编给大家分享谷歌chrome浏览器怎么滚动截图教程,希望对大家有所帮助. 1.打开谷歌chrome浏览器,点击小编红框标记位置应用--应用商店: 谷歌chrome浏览器 应用商店 谷歌chrome浏览器 应用商店 2.搜索"capture page"或者"fireshot": 谷歌chrome浏览器 搜索 3.下载小编红框标记位置的插件: 谷歌chrome