记录几个javascript有关的小细节


Posted in Javascript onApril 02, 2007

很多很多的事都容易在不经意间忘却,所以我选择记录下来。

Firefox 不支持 obj.innerText 属性。

 obj.innerText alert()显示的值是 undefined。

Firefox 支持 innerHTML 属性却不支持 innerText,如果不想用innerHTML 替代,可以用如下代码

由于Firefox不支持document.all,所以考虑兼容的时候获取对象通常用 document.getelementbyid('yourid').

if (document.all) {  //如果不是IE  
//也可以用 if(navigator.appName.indexOf("Explorer") > -1) // obj.innerText = "myText";}else { obj.textContent = "yourtext"; 用textContent 替代 
}

Firefox、IE兼容的复制到剪贴板 javascript 代码

这个函数使用在Firefox下时需要修改一个配置:
1.打开firefox ,在地址栏中输入: about:config
2.找到signed.applets.codebase_principal_support,将值设置为true

function copyToClipboard(txt) { 

  if(window.clipboardData) 
  { 
    window.clipboardData.clearData(); 
    window.clipboardData.setData(Text, txt); 
  } 
  else if(navigator.userAgent.indexOf(Opera) != -1) 
  { 
    window.location = txt; 
  } 
  else if (window.netscape) 
  { 
    try { 
        netscape.security.PrivilegeManager.enablePrivilege(UniversalXPConnect); 
    } 
    catch (e) 
    { 
        alert(!!被浏览器拒绝!\n请在浏览器地址栏输入'about:config'并回车\n然后将'signed.applets.codebase_principal_support'设置为'true'); 
    } 
    var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard); 
    if (!clip) 
        return; 
    var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable); 
    if (!trans) 
        return; 
    trans.addDataFlavor('text/unicode'); 
    var str = new Object(); 
    var len = new Object(); 
    var str = Components.classes[@mozilla.org/supports-string;1].createInstance(Components.interfaces.nsISupportsString); 
    var copytext = txt; 
    str.data = copytext; 
    trans.setTransferData(text/unicode,str,copytext.length*2); 
    var clipid = Components.interfaces.nsIClipboard; 
    if (!clip) 
        return false; 
    clip.setData(trans,null,clipid.kGlobalClipboard); 
  } 
  return true; 

或者用下面这段代码,功能相同。

function CopyToClipboard(meintext)
{
    if (window.clipboardData) 
    {
        // the IE-manier
        window.clipboardData.setData("Text", meintext);
    }
    else if (window.netscape) 
    { 
        // dit is belangrijk maar staat nergens duidelijk vermeld:
        // you have to sign the code to enable this, or see notes below 
        netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');

        // maak een interface naar het clipboard
        var clip = Components.classes['@mozilla.org/widget/clipboard;1']
                        .createInstance(Components.interfaces.nsIClipboard);
        if (!clip) return;
        //alert(clip);
        // maak een transferable
        var trans = Components.classes['@mozilla.org/widget/transferable;1']
                        .createInstance(Components.interfaces.nsITransferable);
        if (!trans) return;

        // specificeer wat voor soort data we op willen halen; text in dit geval
        trans.addDataFlavor('text/unicode');

        // om de data uit de transferable te halen hebben we 2 nieuwe objecten 
        // nodig om het in op te slaan
        var str = new Object();
        var len = new Object();
        var str = Components.classes["@mozilla.org/supports-string;1"]
                        .createInstance(Components.interfaces.nsISupportsString);
        var copytext=meintext;
        str.data=copytext;
        trans.setTransferData("text/unicode",str,copytext.length*2);
        var clipid=Components.interfaces.nsIClipboard;
        if (!clip) return false;
        clip.setData(trans,null,clipid.kGlobalClipboard);
    }
    else
    {
        return false;
    }

    alert("您已经复制: " + meintext);
    return false;
}

用javascript获取客户端电脑名

前几天学习php的时候想实现获取客户端电脑名,在asp及.net下都有实现的例子,但一直没找到办法php下实现的方法。后来在国外的论坛里找到了一些代码,是javascript的。但只能运行于IE环境,而且必须把安全级别设置得相当低才可以。

try
{
var ax = new ActiveXObject("WScript.Network");
document.write('User: ' + ax.UserName + '<br />');
document.write('Computer: ' + ax.ComputerName + '<br />');
}
catch (e)
{
document.write('访问当前电脑名操作被拒绝'+ '<br />');
}

Javascript 相关文章推荐
JavaScript中操作Mysql数据库实例
Apr 02 Javascript
基于Arcgis for javascript实现百度地图ABCD marker的效果
Sep 12 Javascript
详解Bootstrap四种图片样式
Jan 04 Javascript
javascript插件开发的一些感想和心得
Feb 28 Javascript
Vue.js第四天学习笔记(组件)
Dec 02 Javascript
详解基于Vue+Koa的pm2配置
Oct 24 Javascript
JS中精巧的自动柯里化实现方法
Dec 12 Javascript
在vue项目中使用Nprogress.js进度条的方法
Jan 31 Javascript
新版小程序登录授权的方法
Dec 12 Javascript
VUE项目初建和常见问题总结
Sep 12 Javascript
JavaScript oncopy事件用法实例解析
May 13 Javascript
jQuery 选择器用法实例分析【prev + next】
May 22 jQuery
新浪刚打开页面出来的全屏广告代码
Apr 02 #Javascript
js prototype 格式化数字 By shawl.qiu
Apr 02 #Javascript
JXTree对象,读取外部xml文件数据,生成树的函数
Apr 02 #Javascript
新浪中用来显示flash的函数
Apr 02 #Javascript
我也种棵OO树JXTree[js+css+xml]
Apr 02 #Javascript
javascript中获取选中对象的类型
Apr 02 #Javascript
javascript实现动态增加删除表格行(兼容IE/FF)
Apr 02 #Javascript
You might like
PHP+MYSQL的文章管理系统(一)
2006/10/09 PHP
input file获得文件根目录简单实现
2013/04/26 PHP
简单的cookie计数器实现源码
2013/06/07 PHP
js querySelector和getElementById通过id获取元素的区别
2012/04/20 Javascript
JS中判断JSON数据是否存在某字段的方法
2014/03/07 Javascript
Windows系统下使用Sublime搭建nodejs环境
2015/04/13 NodeJs
javascript实现简易计算器的代码
2016/05/31 Javascript
jQuery 判断是否包含在数组中Array[]的方法
2016/08/03 Javascript
Vuejs第八篇之Vuejs组件的定义实例解析
2016/09/05 Javascript
nodejs的HTML分析利器node-jquery用法浅析
2016/11/08 NodeJs
微信小程序 简单教程实例详解
2017/01/13 Javascript
vue.js的安装方法
2017/05/12 Javascript
JavaScript读写二进制数据的方法详解
2018/09/09 Javascript
基于VUE实现的九宫格抽奖功能
2018/09/30 Javascript
javascript中innerHTML 获取或替换html内容的实现代码
2020/03/17 Javascript
Javascript异步流程控制之串行执行详解
2020/09/27 Javascript
[01:10:58]Spirit vs NB Supermajor小组赛 A组败者组决赛 BO3 第二场 6.2
2018/06/03 DOTA
python解析xml文件实例分享
2013/12/04 Python
Python导入oracle数据的方法
2015/07/10 Python
python调用Matplotlib绘制分布点并且添加标签
2018/05/31 Python
利用Python如何批量修改数据库执行Sql文件
2018/07/29 Python
python 实现读取一个excel多个sheet表并合并的方法
2019/02/12 Python
pyqt5 实现在别的窗口弹出进度条
2019/06/18 Python
PyTorch中反卷积的用法详解
2019/12/30 Python
Django单元测试中Fixtures的使用方法
2020/02/26 Python
Python figure参数及subplot子图绘制代码
2020/04/18 Python
关于python scrapy中添加cookie踩坑记录
2020/11/17 Python
新西兰最大、占有率最高的综合性药房:PharmacyDirect药房中文网
2020/11/03 全球购物
Prototype中如何为一个元素添加一个方法
2014/12/08 面试题
公司管理建议书范文
2014/03/12 职场文书
公司2014年度工作总结
2014/12/10 职场文书
物业接待员岗位职责
2015/04/15 职场文书
主婚人致辞精选
2015/07/28 职场文书
2019森林防火宣传标语大全!
2019/07/03 职场文书
golang中切片copy复制和等号复制的区别介绍
2021/04/27 Golang
Java8中Stream的一些神操作
2021/11/02 Java/Android