我试图通过cfm页面传递唯一的数据库会话ID但似乎无法使其正常工作。第1页有记录ID,我试图在recordclick()函数中保存numSession并在下一页中传递它,我在查询中使用它,但它不起作用。
下面简要概述了我在做什么:
第1页:
<CFQUERY datasource = "database1" result = "result">
insert into user
set
blah blah
</cfquery>
<html>
<head>
<title>page1</title>
<script type="text/javascript">
function recordClick(imageid)
{
document.getElementById("numSend").value = document.getElementById("numSend").value + imageid;
document.getElementById("numSession").value = result.generated_key;
}
</script>
</head>
<body>
<FORM action="page2.cfm" method="post">
<img src="1.png" NAME="num1" onclick="recordClick(1)"
width="100px"
height="100px">
<div name="num1" id="num1"></div>
<input type="hidden" id="numSend" name="numSend" />
<input type ="hidden" id = "numSession" name ="numSession" />
<input type="submit" value="Done" />
</form>
</body>
</html>
--------------------------------------
<cfoutput>
The ID of the row I just inserted was "#numSession#"
</cfoutput>
<CFQUERY datasource = "database1">
update user
set
pin = "#numSend#"
where id= "#numSession#"
</cfquery>
答案 0 :(得分:5)
ColdFusion在服务器上执行,JavaScript在客户端上执行。你的JS不知道result
是什么。
您需要使用ColdFusion's ToScript()
function。
<强>描述强>
创建分配值的JavaScript或ActionScript表达式 ColdFusion变量的一个JavaScript或ActionScript变量。 这个函数可以转换ColdFusion字符串,数字,数组, 结构,以及对JavaScript或ActionScript语法的查询 定义等效变量和值。
以下是一个例子,取自文档:
<cfset thisString="hello world">
<script type="text/javascript" language="JavaScript">
<cfoutput>
var #ToScript(thisString, "jsVar")#;
</cfoutput>
</script>
您的代码(已更正):
function recordClick(imageid)
{
var <cfoutput>#ToScript(result.generated_key, "generated_key")#;</cfoutput>
var objNumSend = document.getElementById("numSend");
objNumSend.value = objNumSend.value + imageid;
document.getElementById("numSession").value = generated_key;
}