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 相关文章推荐
JavaScript作用域链示例分享
May 27 Javascript
Iframe实现跨浏览器自适应高度解决方法
Sep 02 Javascript
js实现文章文字大小字号功能完整实例
Nov 01 Javascript
JavaScript中的数组操作介绍
Dec 30 Javascript
Javascript实现多彩雪花从天降散落效果的方法
Feb 02 Javascript
分享一个原生的JavaScript拖动方法
Sep 25 Javascript
js实现旋转木马效果
Mar 17 Javascript
vue双向数据绑定知识点总结
Apr 18 Javascript
浅谈Vue.use的使用
Aug 29 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
Aug 02 Javascript
vue.js 子组件无法获取父组件store值的解决方式
Nov 08 Javascript
js实现盒子拖拽动画效果
Aug 09 Javascript
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
require(),include(),require_once()和include_once()的异同
2007/01/02 PHP
PHP中nowdoc和heredoc使用需要注意的一点
2014/03/21 PHP
IE8 兼容性问题(属性名区分大小写)
2009/06/04 Javascript
Web 前端设计模式--Dom重构 提高显示性能
2010/10/22 Javascript
一个简单的jQuery插件ajaxfileupload.js实现ajax上传文件例子
2014/06/26 Javascript
javascript中CheckBox全选终极方案
2015/05/20 Javascript
最常见和最有用的字符串相关的方法详解
2017/02/06 Javascript
提升页面加载速度的插件InstantClick
2017/09/12 Javascript
JS设计模式之观察者模式实现实时改变页面中金额数的方法
2018/02/05 Javascript
JS处理一些简单计算题
2018/02/24 Javascript
微信小程序中this.data与this.setData的区别详解
2018/09/17 Javascript
Vue.js上传图片到阿里云OSS存储的方法示例
2018/12/13 Javascript
js获取对象,数组所有属性键值(key)和对应值(value)的方法示例
2019/06/19 Javascript
JavaScript数组排序小程序实现解析
2020/01/13 Javascript
深入浅析python中的多进程、多线程、协程
2016/06/22 Python
Tornado高并发处理方法实例代码
2018/01/15 Python
Python使用matplotlib绘制多个图形单独显示的方法示例
2018/03/14 Python
python实现学员管理系统
2019/02/26 Python
详解Python 调用C# dll库最简方法
2019/06/20 Python
如何使用python把ppt转换成pdf
2019/06/29 Python
python自动识别文本编码格式代码
2019/12/26 Python
Pytorch 之修改Tensor部分值方式
2019/12/27 Python
使用卷积神经网络(CNN)做人脸识别的示例代码
2020/03/27 Python
使用Python实现批量ping操作方法
2020/05/06 Python
使用BeautifulSoup4解析XML的方法小结
2020/12/07 Python
python实现图像高斯金字塔的示例代码
2020/12/11 Python
开普敦通行证:Cape Town Pass
2019/07/18 全球购物
英国男女豪华配饰和礼品网站:Black.co.uk
2020/02/28 全球购物
Ruby如何实现动态方法调用
2012/11/18 面试题
绩效工资分配方案
2014/01/18 职场文书
2014三八妇女节活动总结
2014/03/01 职场文书
公务员平时考核实施方案
2014/03/11 职场文书
护士节策划方案
2014/05/19 职场文书
python爬取新闻门户网站的示例
2021/04/25 Python
redis通过6379端口无法连接服务器(redis-server.exe闪退)
2021/05/08 Redis
P站美图推荐——变身女主角特辑
2022/03/20 日漫