JS动态调用方法名示例介绍


Posted in Javascript onDecember 18, 2013

先看看JS的一个函数

JavaScript eval() 函数
定义和用法

eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。
语法

eval(string)

参数 描述

string 必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。

返回值

通过计算 string 得到的值(如果有的话)。

说明

该方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。因此请不要为 eval() 函数传递 String 对象来作为参数。

如果试图覆盖 eval 属性或把 eval() 方法赋予另一个属性,并通过该属性调用它,则 ECMAScript 实现允许抛出一个 EvalError 异常。

抛出

如果参数中没有合法的表达式和语句,则抛出 SyntaxError 异常。

如果非法调用 eval(),则抛出 EvalError 异常。

如果传递给 eval() 的 Javascript 代码生成了一个异常,eval() 将把该异常传递给调用者。

提示和注释

提示:虽然 eval() 的功能非常强大,但在实际使用中用到它的情况并不多。

实例

例子 1

在本例中,我们将在几个字符串上运用 eval(),并看看返回的结果:

<script type="text/javascript"> eval("x=10;y=20;document.write(x*y)") 
document.write(eval("2+2")) 
var x=10 
document.write(eval(x+17)) 
</script>

输出:

200
4
27

例子 2

看一下在其他情况中,eval() 返回的结果:

eval("2+3") // 返回 5 
var myeval = eval; // 可能会抛出 EvalError 异常 
myeval("2+3"); // 可能会抛出 EvalError 异常

可以使用下面这段代码来检测 eval() 的参数是否合法:
try { 
alert("Result:" + eval(prompt("Enter an expression:",""))); 
} catch(exception) { 
alert(exception); 
}

第一种方法就是使用js里面的eval

下面是自己写的例子

call("showmsg"); function call(functionName){ 
eval("this."+functionName+"()"); 
} 
function showmsg(){ 
alert("success"); 
}

eval能将你拼接的字符串自动识别为方法,并调用。

但弊端也是很大的,想象一下,某个人改你调用地方的方法名,便能调用你的任意方法。

第二种方法主要用作自己定义的方法

主要是第二种方法需要特定的方式去写

function call(functionName) { 
showmsgs["showmsg"](); 
} var showmsgs = { showmsg: function () { 
alert("success"); 
} 
} 
call("showmsg");
Javascript 相关文章推荐
基于jquery自定义的漂亮单选按钮RadioButton
Nov 19 Javascript
jQuery实现的一个tab切换效果内部还嵌有切换
Aug 10 Javascript
HTML5之WebSocket入门3 -通信模型socket.io
Aug 21 Javascript
理解javascript闭包
Dec 15 Javascript
JavaScript条件判断_动力节点Java学院整理
Jun 26 Javascript
JS中跳出循环的示例代码
Sep 14 Javascript
jQuery结合jQuery.cookie.js插件实现换肤功能示例
Oct 14 jQuery
微信小程序自定义底部导航带跳转功能
Nov 27 Javascript
微信小程序在text文本实现多种字体样式
Nov 08 Javascript
微信公众号网页分享功能开发的示例代码
May 27 Javascript
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
Vue实现动态查询规则生成组件
May 27 Vue.js
javascript页面动态显示时间变化示例代码
Dec 18 #Javascript
页面实时更新时间的JS实例代码
Dec 18 #Javascript
带左右箭头图片轮播的JS代码
Dec 18 #Javascript
用js代码改变单选框选中状态的简单实例
Dec 18 #Javascript
浅析document.ready和window.onload的区别讲解
Dec 18 #Javascript
浅谈Javascript 执行顺序
Dec 18 #Javascript
Javascript浅谈之引用类型
Dec 18 #Javascript
You might like
JSON在PHP中的应用介绍
2012/09/08 PHP
PHP安装threads多线程扩展基础教程
2015/11/17 PHP
PHP函数checkdnsrr用法详解(Windows平台用法)
2016/03/21 PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
2018/06/16 PHP
php微信开发之关注事件
2018/06/14 PHP
php的扩展写法总结
2019/05/14 PHP
javascript实现动态CSS换肤技术的脚本
2007/06/29 Javascript
Prototype ObjectRange对象学习
2009/07/19 Javascript
JSON 入门指南 想了解json的朋友可以看下
2009/08/26 Javascript
JavaScript去掉数组中的重复元素
2011/01/13 Javascript
一个关于jqGrid使用的小例子(行按钮)
2011/11/04 Javascript
jquery ajax应用中iframe自适应高度问题解决方法
2014/04/12 Javascript
Javascript基础知识(二)事件
2014/09/29 Javascript
jQuery选择器源码解读(三):tokenize方法
2015/03/31 Javascript
JavaScript 不支持 indexof 该如何解决
2016/03/30 Javascript
原生js和jquery分别实现横向导航菜单效果
2016/05/13 Javascript
vue多种弹框的弹出形式的示例代码
2017/09/18 Javascript
Vue.js 中取得后台原生HTML字符串 原样显示问题的解决方法
2018/06/10 Javascript
node删除、复制文件或文件夹示例代码
2019/08/13 Javascript
JS中的算法与数据结构之链表(Linked-list)实例详解
2019/08/20 Javascript
vue v-for出来的列表,点击某个li使得当前被点击的li字体变红操作
2020/07/17 Javascript
[01:00]DOTA2 store: Collection of Artisan's Wonders
2015/08/12 DOTA
Python获取央视节目单的实现代码
2015/07/25 Python
python实现两个文件合并功能
2018/04/01 Python
python破解zip加密文件的方法
2018/05/31 Python
python3 unicode列表转换为中文的实例
2018/10/26 Python
Python 使用PyQt5 完成选择文件或目录的对话框方法
2019/06/27 Python
Python操作Mongodb数据库的方法小结
2019/09/10 Python
Python将列表中的元素转化为数字并排序的示例
2019/12/25 Python
Python如何绘制日历图和热力图
2020/08/07 Python
校长岗位职责
2013/11/26 职场文书
勾股定理课后反思
2014/04/26 职场文书
2016年小学生清明节广播稿
2015/12/17 职场文书
调解协议书范本
2016/03/21 职场文书
Python超详细分步解析随机漫步
2022/03/17 Python
Python实现批量将文件复制到新的目录中再修改名称
2022/04/12 Python