记录几个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实现无间缝滚动示例
Jan 28 Javascript
jQuery控制Div拖拽效果完整实例分析
Apr 15 Javascript
JavaScript实现的背景自动变色代码
Oct 17 Javascript
JavaScript实现三级联动效果
Jul 15 Javascript
JS实现基于Sketch.js模拟成群游动的蝌蚪运动动画效果【附demo源码下载】
Aug 18 Javascript
vue+node+webpack环境搭建教程
Nov 05 Javascript
如何从零开始利用js手写一个Promise库详解
Apr 19 Javascript
vue 中 beforeRouteEnter 死循环的问题
Apr 23 Javascript
vue 路由守卫(导航守卫)及其具体使用
Feb 25 Javascript
react 原生实现头像滚动播放的示例
Apr 21 Javascript
Vue路由切换页面不更新问题解决方案
Jul 10 Javascript
vue-router重写push方法,解决相同路径跳转报错问题
Aug 07 Javascript
新浪刚打开页面出来的全屏广告代码
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设计模式 Factory(工厂模式)
2011/06/26 PHP
深入解析fsockopen与pfsockopen的区别
2013/07/05 PHP
PHP实现的线索二叉树及二叉树遍历方法详解
2016/04/25 PHP
php5.2的curl-bug 服务器被php进程卡死问题排查
2016/09/19 PHP
PHP实现断点续传乱序合并文件的方法
2018/09/06 PHP
Avengerls vs KG BO3 第一场2.18
2021/03/10 DOTA
33个优秀的jQuery 教程分享(幻灯片、动画菜单)
2011/07/08 Javascript
jQuery EasyUI API 中文文档 - MenuButton菜单按钮使用介绍
2011/10/06 Javascript
jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例
2013/06/17 Javascript
jquery弹出框的用法示例(2)
2013/08/26 Javascript
JavaScript prototype 使用介绍
2013/08/29 Javascript
js数组循环遍历数组内所有元素的方法
2014/01/18 Javascript
瀑布流布局代码一例
2014/04/11 Javascript
Actionscript与javascript交互实例程序(修改)
2016/09/22 Javascript
nodejs mysql 实现分页的方法
2017/06/06 NodeJs
vue+vuecli+webpack中使用mockjs模拟后端数据的示例
2017/10/24 Javascript
在vue中,v-for的索引index在html中的使用方法
2018/03/06 Javascript
Vue数据绑定简析小结
2019/05/07 Javascript
微信小程序后端无法保持session的原因及解决办法问题
2020/03/20 Javascript
[43:53]OG vs EG 2019国际邀请赛淘汰赛 胜者组 BO3 第三场 8.22
2019/09/05 DOTA
Python2.7 实现引入自己写的类方法
2018/04/29 Python
win7下python3.6安装配置方法图文教程
2018/07/31 Python
对python读取zip压缩文件里面的csv数据实例详解
2019/02/08 Python
Django 用户认证组件使用详解
2019/07/23 Python
Python2与Python3的区别详解
2020/02/09 Python
Python 实现敏感目录扫描的示例代码
2020/05/21 Python
CSS实现雨滴动画效果的实例代码
2019/10/08 HTML / CSS
手工制作的意大利太阳镜和光学元件:Illesteva
2019/01/19 全球购物
马云的职业生涯规划之路
2014/01/01 职场文书
分公司总经理岗位职责
2014/08/03 职场文书
2014年入党积极分子学习三中全会思想汇报
2014/09/13 职场文书
不遵守课堂纪律的检讨书
2014/09/24 职场文书
病房管理制度范本
2015/08/06 职场文书
小学英语教学随笔
2015/08/14 职场文书
中小学教师继续教育心得体会
2016/01/19 职场文书
Mysql 如何批量插入数据
2021/04/06 MySQL