c#treeview设置NavigateUrl跳转并同时取父节点值 我只能实现其中一种

c#treeview设置NavigateUrl跳转并同时取父节点值 我只能实现其中一种,第1张

设置节点的NavigateUrl=“javascript:getNodeVal(this);”,在javascript的方法getNodeVal中设置页面跳转,并且能够获得节点的值,如果想获得父节点的值也行,将父节点的值通过该javascript方法传到getNodeVal中,怎用都行 ,你说了算!

如何实现刷新当前页面呢?借助js你将无所不能。

1,reload 方法,该方法强迫浏览器刷新当前页面。

语法:locationreload([bForceGet])

参数: bForceGet, 可选参数, 默认为 false,从客户端缓存里取当前页。true, 则以 GET 方式,从服务端取最新的页面, 相当于客户端点击 F5("刷新")

2,replace 方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,你不能通过“前进”和“后退”来访问已经被替换的URL。

语法: locationreplace(URL)

通常使用: locationreload() 或者是 historygo(0) 来做。

此方法类似客户端点F5刷新页面,所以页面method="post"时,会出现"网页过期"的提示。

因为Session的安全保护机制。

当调用 locationreload() 方法时, aspx页面此时在服务端内存里已经存在, 因此必定是 IsPostback 的。

如果有这种应用: 需要重新加载该页面,也就是说期望页面能够在服务端重新被创建,期望是 Not IsPostback 的。

这里,locationreplace() 就可以完成此任务。被replace的页面每次都在服务端重新生成。

代码: locationreplace(locationhref);

返回并刷新页面:

locationreplace(documentreferrer);

documentreferrer //前一个页面的URL

不要用 historygo(-1),或 historyback();来返回并刷新页面,这两种方法不会刷新页面。

附:

Javascript刷新页面的几种方法:

复制代码 代码如下:

1,historygo(0)

2,locationreload()

3,location=location

4,locationassign(location)

5,documentexecCommand('Refresh')

6,windownavigate(location)

7,locationreplace(location)

8,documentURL=locationhref

自动刷新页面的方法:

1,页面自动刷新:把如下代码加入<head>区域中

复制代码 代码如下:

<meta >

通过webBrowser实现C#和javascript互调

实现步骤:

一、新建一个窗体,加入webBrowser控件

控件名:webBrowser1

二、在窗体后台代码加入如下定义

[SystemRuntimeInteropServicesComVisibleAttribute(true)]

public partial class Form1 : Form

{

}

三、加载网页

webBrowser1Navigate(ApplicationStartupPath + "/UpDateReporthtm");

webBrowser1ObjectForScripting = this; //这句必须,不然js不能调用C#

四、调用脚本方法

/// <summary>

/// 脚本方法

/// </summary>

/// <param name="tag">JS函数名|参数1|参数2</param>

/// <returns></returns>

private object EXEC_JS(SystemWindowsFormsWebBrowser webBrowser, string tag)

{

string[] args = tagSplit('|');

if (argsLength == 1)

{

return webBrowserDocumentInvokeScript(args[0], null);

}

else

{

object[] objects = new object[argsLength - 1];

ArrayCopy(args, 1, objects, 0, objectsLength);

return webBrowserDocumentInvokeScript(args[0], objects);

}

}

五、C#调用脚本方法例子,可以有返回值

//JS方法

<script language="javascript">

function js_fun(args)

{

alert("我是通过js脚本d出的。你输入的内容是:"+args);

return "JAVASCRIPT";

}

</script>

//C#代码

object returnvalue = EXEC_JS(webBrowser1, "js_fun|参数字符串");

MessageBoxShow("js方法返回值是:" + returnvalueToString());

六、JS调用C#方法的例子

//C#方法

public string Test(string args)

{

return "你输入的是:"+args;

}

//JS代码

<script language="javascript">

windowonload = function()

{

var CS_returnvalue= windowexternalTest("aaa");

alert(CS_returnvalue);

}

</script>

通过webBrowser实现C#和javascript互调

实现步骤:

一、新建一个窗体,加入webBrowser控件

控件名:webBrowser1

二、在窗体后台代码加入如下定义

[SystemRuntimeInteropServicesComVisibleAttribute(true)]

public partial class Form1 : Form

{

}

三、加载网页

webBrowser1Navigate(ApplicationStartupPath + "/UpDateReporthtm");

webBrowser1ObjectForScripting = this; //这句必须,不然js不能调用C#

四、调用脚本方法

/// <summary>

/// 脚本方法

/// </summary>

/// <param name="tag">JS函数名|参数1|参数2</param>

/// <returns></returns>

private object EXEC_JS(SystemWindowsFormsWebBrowser webBrowser, string tag)

{

string[] args = tagSplit('|');

if (argsLength == 1)

{

return webBrowserDocumentInvokeScript(args[0], null);

}

else

{

object[] objects = new object[argsLength - 1];

ArrayCopy(args, 1, objects, 0, objectsLength);

return webBrowserDocumentInvokeScript(args[0], objects);

}

}

五、C#调用脚本方法例子,可以有返回值

//JS方法

<script language="javascript">

function js_fun(args)

{

alert("我是通过js脚本d出的。你输入的内容是:"+args);

return "JAVASCRIPT";

}

</script>

//C#代码

object returnvalue = EXEC_JS(webBrowser1, "js_fun|参数字符串");

MessageBoxShow("js方法返回值是:" + returnvalueToString());

六、JS调用C#方法的例子

//C#方法

public string Test(string args)

{

return "你输入的是:"+args;

}

//JS代码

<script language="javascript">

windowonload = function()

{

var CS_returnvalue= windowexternalTest("aaa");

alert(CS_returnvalue);

}

</script>

第一种:(跳转到bhtml)

<script language="javascript" type="text/javascript">

windowlocationhref="bhtml";

</script>

第二种:(返回上一页面)

<script language="javascript">

windowhistoryback(-1);

</script>

第三种:

<script language="javascript">

windownavigate("bhtml");

</script>

第四种:

<script language="JavaScript">

selflocation=’bhtml’;

</script>

第五种:

以上就是关于c#treeview设置NavigateUrl跳转并同时取父节点值 我只能实现其中一种全部的内容,包括:c#treeview设置NavigateUrl跳转并同时取父节点值 我只能实现其中一种、JS代码如何刷新页面后显示不一样的段落、webbrowser 里面的js怎么调用C#等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9820719.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存