0
我正在创建一些任务,我正在创建一些动态的输入控件,并且正在使用c#代码中的streamwriter创建一个js文件来验证输入控件。现在我想在我的aspx页面中添加对当前创建的js文件的引用。从javascript函数添加js文件ref
我的创建输入控件方法是一个webmethod,我从客户端使用ajax-json进行调用。 Web方法:
[WebMethod]
public static string LoadDatanGenerateControls(int PostTypeID, int CategoryID)
{
DataTable dtControls = new DataTable();
StringBuilder sb = new StringBuilder();
dtControls = PostingExtendedFields.GetExtendedDFields(PostTypeID, CategoryID);
sb.Append("<table>");
foreach (DataRow dr in dtControls.Rows)
{
sb.Append("<tr><td>");
sb.Append("<input value=';" + dr["RequiredError"].ToString() + "'; type=';text'; size=';20'; id=';txt_" + dr["FieldName"].ToString() + "'; class=';riTextBox riEmpty'; style=';width:450px;'; onfocus =';Focus(this);'; onblur=\"Blur(this,';" + dr["RequiredError"].ToString() + "';);\"/>");
sb.Append("</td></tr>");
}
sb.Append("</table>");
//create the js file
string path = HttpContext.Current.Server.MapPath("") + "\\";
if (File.Exists(path + "sale.js")) File.Delete(path + "sale.js");//delete if exist
using (StreamWriter sw = new StreamWriter(path + "sale.js"))
{
sw.WriteLine("function Focus(obj) {");
sw.WriteLine("var id = obj.id;");
sw.WriteLine("$(';#'; + id).val(';';);");
sw.WriteLine(" }");
sw.WriteLine("function Blur(obj, title) {");
sw.WriteLine("var id = obj.id;");
sw.WriteLine("if ($(';#'; + id).val() == ';';) {");
sw.WriteLine("$(';#'; + id).val(title);");
sw.WriteLine("}");
sw.WriteLine(" }");
}
return sb.ToString();
}
在aspx页面:
function LoadControls() {
try {
var types = $find("<%= ddlPost.ClientID %>");
var Category = $find("<%= ddlCategory.ClientID %>");
var typeID = types.get_value();
var catID = Category.get_value();
///web method
$(';#TDDynamicContents';).html(';';);
$.ajax({
type: "POST",
url: "Default.aspx/LoadDatanGenerateControls",
data: "{';PostTypeID';:';" + typeID + "';,';CategoryID';:';" + catID + "';}",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function(msg) {
if (msg.d.length > 0) {
$(';#TDDynamicContents';).html(msg.d);
//add js file path
addjsfile("sale.js", "js")
}
},
async: false,
error: function(xhr, status, error) {
alert(xhr.statusText);
}
});
} catch (e) { }
}
function addjsfile(filename, filetype) {
alert(filetype);
if (filetype == "js") {
var fileref = document.createElement(';script';);
fileref.setAttribute("type", "text/javascript");
fileref.setAttribute("src", filename);
}
if (typeof fileref != "undefined") {
document.getElementsByTagName("head")[0].appendChild(fileref);
alert(fileref);
}
}
但我addjsfile功能不工作。 它没有在头部添加引用,我无法使用js文件中的函数。