JS关键字变色实现思路及代码
JS关键字变色实现思路及代码
发布时间:2016-12-30 来源:查字典编辑
摘要:1.替换关键字,对字体变色复制代码代码如下:publicstaticstringReplaceRed(stringstrtitle,stri...

1.替换关键字,对字体变色

复制代码 代码如下:

public static string ReplaceRed(string strtitle, string redkey)

{

if (redkey == "" || redkey == null)

{

return strtitle;

}

else

strtitle = strtitle.Replace(redkey, " <font color='#ff0000'>" + redkey + " </font>");

return strtitle;

}

该方法缺点是:点字符是含大小写的英文时,变色后统一替换为了关键字的大小写,体验不好。

2.用正则,CSS背景变色

复制代码 代码如下:

protected string HighlightText(string inputText,string searchWord)

{

System.Text.RegularExpressions.Regex expression = new System.Text.RegularExpressions.Regex(searchWord.Replace(" ", "|"), System.Text.RegularExpressions.RegexOptions.IgnoreCase);

return expression.Replace(inputText,new System.Text.RegularExpressions.MatchEvaluator(ReplaceKeywords));

}

public string ReplaceKeywords(System.Text.RegularExpressions.Match m)

{

return "<span>" + m.Value + "</span>";//关键字背景加色

//return "<font color='#ff0000'>" + m.Value + "</font>";//关键字变色

}

该方法可结合前台JS调用:

复制代码 代码如下:

<style type="text/css">

.highlightTxtSearch

{

background-color:Yellow;

}

</style>

复制代码 代码如下:

<script type="text/javascript">

$(function () {

$('#tt').datagrid({

url: '@Url.Content("~/Domain/LoadDomainAdmin")',

width: "90%",

height: 400,

fitColumns: true,

nowrap: false,

idField: 'UserID',

pagination: true,

pageNumber: 1,

singleSelect: true,

frozenColumns: [[{ field: 'radio', formatter: function (value, row, index) {

return '<input type="radio" name="rd_action" />';

}

}]],

columns: [[

{ field: 'UserID', title: 'UserID', width: 260, hidden: 'true' },

{ field: 'LoginName', title: '@ViewBag.LoginName', width: 180, align: 'left', formatter: function (data) {

//return "<div>" + data + "</div>";

return GetNewData(data);

}

},

{ field: 'FirstName', title: '@ViewBag.FirstName', width: 120, align: 'left', formatter: function (data) {

//return "<div title=" + data + ">" + data + "</div>";

return GetNewData(data);

// var keyword = $.trim($("#txtInfo").val()) == '@ViewBag.SearchText' ? "" : $.trim($("#txtInfo").val());

// if (keyword == "") {

// return "<div title=" + data + ">" + data + "</div>";

// }

// else {

// var returnData = "";

// $.ajax({

// type: "POST",

// url: '@Url.Content("~/Domain/HighlightText")' + "?inputText=" + data + "&searchWord=" + keyword,

// async: false,

// success: function (newdata) {

// //重新赋值

// returnData = newdata;

// },

// error: function () {

// //不修改returnData值

// }

// });

// return "<div title=" + data + ">" + returnData + "</div>";

// }

}

},

{ field: 'LastName', title: '@ViewBag.LastName', width: 120, align: 'left', formatter: function (data) {

//return "<div title=" + data + ">" + data + "</div>";

return GetNewData(data);

}

},

{ field: 'Email', title: '@ViewBag.Email', width: 180, align: 'left', formatter: function (data) {

return "<div title=" + data + ">" + data + "</div>";

}

},

// { field: 'Domian', title: '@ViewBag.Domian', width: 180, align: 'left', formatter: function (data) {

// return "<div title=" + data + ">" + data + "</div>";

// }

// },

// { field: 'Role', title: '@ViewBag.Role', width: 180, align: 'left', formatter: function (data) {

// return "<div title=" + data.replace(" ", "").replace(" ", "") + ">" + data + "</div>";

// }

// },

// {field: 'IsEnabled', title: '@ViewBag.State', align: 'center', width: 150, formatter: function (val) {

// if (val == true)

// return "<div>True</div>";

// else

// return "<div>False</div>";

// }

// }

]],

onBeforeLoad: function (row, param) {

//移除头部批量勾选框

$(".datagrid-header-check input").css("visibility", "hidden");

//隐藏分页

//$(".datagrid-pager").css("display", "none");

//$(".datagrid-pager").removeClass("datagrid-pager");

return true;

},

onLoadSuccess: function (data) {

if (data.rows.length == 0) {

$(".datagrid-view2 .datagrid-body").html("<div>" + userManage_index_SearchMsg + "</div>");

}

else {

$('#tt').datagrid('selectRecord', '@ViewBag.AdminId');

$("input[name=rd_action]", $("div.datagrid-view1 tr.datagrid-row-selected")).attr("checked", "checked");

}

$("div.datagrid-header-check input").removeAttr("checked"); //重新加载时去掉复选框的选中

//$('#tt').datagrid('unselectAll');

var queryParams = $('#tt').datagrid('options').queryParams;

queryParams.IsSerach = "NO";

queryParams.DomainId = $("#xDomainId").val();

$('#tt').datagrid('options').queryParams = queryParams;

},

// onSelect: function () {

// ChSelect();

// },

// onUnselect: function () {

// ChSelect();

// },

onClickRow: function (row) {

$("input[name=rd_action]", $("div.datagrid-view1 tr.datagrid-row-selected")).attr("checked", "checked");

}

});

var p = $('#tt').datagrid('getPager');

$(p).pagination({

pageNumber: 1,

pageSize: 10, //每页显示的记录条数,默认为10

pageList: [5, 10, 15], //可以设置每页记录条数的列表

displayMsg: "" //'当前显示 {from} - {to} 条记录 共 {total} 条记录',

});

$("#btn_search").click(function () {

$("#importErrorMsg").find("div").css("display", "none");

var queryParams = $('#tt').datagrid('options').queryParams;

queryParams.FullName = $.trim($("#txtInfo").val()) == '@ViewBag.SearchText' ? "" : $.trim($("#txtInfo").val());

queryParams.IsSerach = "YES";

$('#tt').datagrid('options').queryParams = queryParams;

$("#tt").datagrid('reload');

var p = $('#tt').datagrid('getPager');

$(p).pagination({

pageNumber: 1,

pageList: [5, 10, 15], //可以设置每页记录条数的列表

displayMsg: "" //'当前显示 {from} - {to} 条记录 共 {total} 条记录',

});

})

$(".pagination-num").keydown(function (event) {

var event = event || window.event;

if (event.keyCode == 13)

event.keyCode = 9;

if ((event.keyCode < 48 || event.keyCode > 57) && event.keyCode != 8 && event.keyCode != 46 && (event.keyCode < 96 || event.keyCode > 105)) {

event.preventDefault();

event.returnValue = false;

}

});

$(".datagrid-cell").css("textAlign", "center"); //表头内容居中

});

function ChSelect() {

// var row = $('#tt').datagrid('getChecked');

// var rows = $('#tt').datagrid('getRows');

// row.length == rows.length ? $("div.datagrid-header-check input").attr("checked", true) : $("div.datagrid-header-check input").removeAttr("checked");

}

function GetNewData(data) {

var keyword = $.trim($("#txtInfo").val()) == '@ViewBag.SearchText' ? "" : $.trim($("#txtInfo").val());

if (keyword == "") {

return "<div title=" + data + ">" + data + "</div>";

}

else {

var returnData = "";

$.ajax({

type: "POST",

url: '@Url.Content("~/Domain/HighlightText")' + "?inputText=" + data + "&searchWord=" + keyword,

async: false,

success: function (newdata) {

//重新赋值

returnData = newdata;

},

error: function () {

//不修改returnData值

}

});

return "<div title=" + data + ">" + returnData + "</div>";

//title中的data要和后面的data分开,不要后台返回的会让title中的data也跟着改变

}

}

</script>

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类