我有一个Reason来使用Evercookie,它可以在HTML页面中正常工作但我无法在回发后从代码隐藏中获得它的价值。
我通过使用隐藏字段找到了一种解决方法,但是在回发后它总是丢失它的值:
<input type="hidden" id="hfimageurl" name="hfimageurl" value="" />
<script>
var ec2 = new evercookie();
document.getElementById('hfimageurl').value = "User";
ec2.get("id", function (value) { if (value == '10') {
document.getElementById('hfimageurl').value = "BadUser"; }
});
ec2.get("id", function (value) { alert(value); });
</script>
在回发后的代码隐藏中,我总是得到val
='':
string val = Request.Form("hfimageurl");
if (val != "BadRequest") {
}
请注意,警报会正确显示值。
我在这里缺少什么?
答案 0 :(得分:0)
Add runat server to you input
<input type="hidden" id="hfimageurl" name="hfimageurl" value="" runat="server" />
并在页面加载事件中重新分配隐藏的字段值,以便下次回发时不会丢失
protected void Page_Load(object sender, eventargs e)
{
if(Request.Form("hfimageurl") != null)
{
if(hfimageurl.Value == "")
{
hfimageurl.Value=Request.Form("hfimageurl");
}
else
{
//Check if there is a new value, if is, change the value to new one
//Otherwise the value should be saved with postback, but it may be lost
if(!hfimageurl.Value.Equals(Request.Form("hfimageurl"))
{
hfimageurl.Value=Request.Form("hfimageurl");
}
}
}
}