javascript-JavaScript找不到已经定义的函数

问题描述

JavaScript找不到已经定义的函数
 ready: function() {
        setup();
        function setup() {
            for(i=0;i<s.length-1;i++)  {
                var j = i+1;
                document.getElementById(s[i]).onchange = new Function("change("+ j +")");//这里有个change,但是这个change为什么提示说找不到
            }
            change(0);//而这个change可以正常使用
        }
        function change(v) {
           //里面的代码是次要的,为什么s[i]内容改变触发onchange后找不到定义好的change呢?
        }
    },

错误提示:Uncaught ReferenceError: change is not defined
请问老师改如何修改能让onchange触发后找到change函数,谢谢。

解决方案

为什么?
我看你没用库,你应该了解点原生的js,有个很重要的概念叫执行环境:一个函数进入到执行环境中会初始化一些东西,包括this和arguments。注意
这个初始化,它依赖的是函数的执行环境,可以联系call和apply来理解。那么问题来了,你给onchange绑定一个函数,这个函数到element-change的
时候才会执行,它执行的时候你上面这段代码早已经不在运行环境中了,这个change的函数要到哪里去找?
解决办法:
1.全局环境不会被销毁,用window.change = change将函数挂在全局上。
2.用一个匿名函数包装:

 document.getElementById(s[i]).onchange = function(){ change("+ j +") };

解决方案二:

javascript:两种注释,声明变量,定义函数。
JavaScript中函数的定义
JavaScript中定义回调函数

解决方案三:

 document.getElementById(s[i]).onchange = new Function("change("+ j +")");
->
document.getElementById(s[i]).onchange = function(j) { change(j); };
时间: 2024-09-20 00:20:21

javascript-JavaScript找不到已经定义的函数的相关文章

JavaScript实现找质数代码分享

 这篇文章主要介绍了JavaScript实现找质数代码分享,本文直接给出实现代码,需要的朋友可以参考下     好吧,也没有背景说明,没有高深技能,纯粹无聊,想找出10000内的所有质数.那么就开始了: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 function zhishu(num) { if (num == 1) { return false; } if (num == 2) { return true; } for (var i = 2; i <= Math.s

基于JavaScript如何实现ajax调用后台定义的方法_jquery

由于ajax的独特优势,使得它在当前大量网站得到了广泛的应用,下面就介绍一下ajax如何调用后台定义的函数,虽然比较简单,不过希望能够给初学者带来一定的帮助,代码如下: 1.首先我们先创建一个antzone.aspx页面. 2.在它的cs文件中创建如下函数: public static string mytest(string first, string second) { return return first+second; } 2.html代码如下: <form id="myform

JavaScript 面向对象编程(2) 定义类_js面向对象

本文承接上一篇JavaScript面向对象编程(1) 基础. 上篇说过,JavaScript没有类的概念,需要通过函数来实现类的定义.先通过一个例子说明: 复制代码 代码如下: function myClass() { var id = 1; var name = "johnson"; //properties this.ID = id; this.Name = name; //method this.showMessage = function() { alert("ID:

详解JavaScript的闭包、IIFE、apply、函数与对象_javascript技巧

目录 一.闭包(Closure) 1.1.闭包相关的问题 1.2.理解闭包 二.对象 2.1.对象常量(字面量) 2.2.取值 2.3.枚举(遍历) 2.4.更新与添加 2.5.对象的原型 2.6.删除 2.7.封装 三.函数 3.1.参数对象 (arguments) 3.2.构造函数 3.3.函数调用 3.3.1.call 3.3.2.apply 3.3.3.caller 3.3.4.Callee 3.5.立即执行函数表达式 (IIFE) 3.5.1.匿名函数与匿名对象 3.5.2.函数与函数

java spring junit-java junit测试报错找不到自己定义的xml文件 跪求各位高手帮忙解决一下

问题描述 java junit测试报错找不到自己定义的xml文件 跪求各位高手帮忙解决一下 eclipse下junit测试时遇到如下错误,错误内容如下: at jp.co.dgic.eclipse.jdt.internal.junit.runner.DJUnitRunner.main(DJUnitRunner.java:49) caused by:org.springframework.beans.factory. BeanDefinitionStoreException:IoException

JavaScript子窗口调用父窗口变量和函数的方法_javascript技巧

本文实例讲述了JavaScript子窗口调用父窗口变量和函数的方法.分享给大家供大家参考.具体如下: 示例1:子窗口是新打开的窗口 父窗口: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns=" http://www.w3.

基于JavaScript实现一定时间后去执行一个函数_javascript技巧

在实际需要中可能需要规定在指定的时间之后再去执行一个函数以达成期望的目的,这也就是一个定时器效果,恰好在js中就已经给定了这样的一个函数setTimeout(),下面先介绍一下次函数的 用法: 语法:  复制代码 代码如下: setTimeout(code,interval) 此函数能够规定在指定的在指定的事件之后去执行一段指定代码,此代码只执行一次. setTimeout()函数具有两个参数,第一个参数规定要执行的执行代码,第二个参数规定在多长时间后去执行代码,单位是毫秒. 代码实例: <!D

对new functionName()定义一个函数的理解_基础知识

比如定义一个函数的两种调用方法: 复制代码 代码如下: function getInfo() { var info = { message: "message" }; return info; } 1.var info1 = getInfo(); 2.var info2 = new getInfo(); 1和2有什么区别吗?info1和info2得到的值是一样的吗? 第1种很简单,用的也很多,就是执行一个函数,并接受函数的返回值并赋给info1对象: 第2种情况一般就很少见了.首先,函

第13周报告2:定义自定义函数,计算sin和cos的近似值

任务2:先听故事,再编程序.故事是这样的:话说sin和cos是一对夫妇.一天,sin去听相声了,cos在家.过了一会,有人敲门,cos开门一看,是一个不认识的多项式函数.cos问:你是谁啊?他说:我是你的老公sin啊.cos说:你不是去听相声了吗?怎么成这幅摸样了?他说:是啊,太乐了!故事讲完了.不懂吗?好好学高数.否则,挂了不冤.   编程序求出sin(π/2).cos(87°) 程序的要求是这样的:(1)求sin.cos时,不能用数学库函数(即不得用#include<Cmath>),而是自