zoukankan      html  css  js  c++  java
  • jquery 仿文本编辑器(智能提示输入文字)

    1.前台代码

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="InputAutoCompelete.aspx.cs" Inherits="HraWeb.InputAutoCompelete" %>

    <!DOCTYPE html>

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    </head>
    <body>
    <form id="form1" runat="server">
    <div>
    </div>
    </form>
    </body>
    </html>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>搜索词自动完成</title>
    <style type="text/css">
    #search {
    text-align: center;
    position: relative;
    }

    .autocomplete {
    border: 1px solid #9ACCFB;
    background-color: white;
    text-align: left;
    }

    .autocomplete li {
    list-style-type: none;
    }

    .clickable {
    cursor: default;
    }

    .highlight {
    background-color: #9ACCFB;
    }
    </style>

    <%--<script type="text/javascript" src="Scripts/jquery.js"></script>--%>
    <script type="text/javascript">
    String.prototype.trimStart = function (trimStr) {
    if (!trimStr) { return this; }
    var temp = this;
    while (true) {
    if (temp.substr(0, trimStr.length) != trimStr) {
    break;
    }
    temp = temp.substr(trimStr.length);
    }
    return temp;
    };
    String.prototype.trimEnd = function (trimStr) {
    if (!trimStr) { return this; }
    var temp = this;
    while (true) {
    if (temp.substr(temp.length - trimStr.length, trimStr.length) != trimStr) {
    break;
    }
    temp = temp.substr(0, temp.length - trimStr.length);
    }
    return temp;
    };
    String.prototype.trim = function (trimStr) {
    var temp = trimStr;
    if (!trimStr) { temp = " "; }
    return this.trimStart(temp).trimEnd(temp);
    };
    String.prototype.endWith = function (endStr) {
    var d = this.length - endStr.toString().length;
    return (d >= 0 && this.lastIndexOf(endStr) == d)
    }
    var ciku = [];
    function getSelectText2(id) {
    var t = document.getElementById(id);
    // alert("start=" + t.selectionStart + "end=" + t.selectionEnd);
    if (window.getSelection) {
    if (t.selectionStart != undefined && t.selectionEnd != undefined) {
    selectionStart = t.selectionStart;
    selectionEnd = t.selectionEnd;
    return t.value.substring(t.selectionStart, t.selectionEnd);
    } else {
    return "";
    }
    } else {
    return document.selection.createRange().text;
    }

    }
    var dbClick = false;
    var sel = false;
    var selectionStart = "";
    var selectionEnd = "";
    $(function () {
    $("#btn1").click(function () {
    //alert(sel);

    alert("input=" + $searchInput.val().length);
    alert("selectionstart=" + selectionStart);
    alert("selectionend=" + selectionEnd);
    //alert(getSelectText2("search-text"));
    });
    $("#clear_Content").on("click", function () {
    $("#search-text").val("");
    ciku = [];
    });
    var cur_danci = "";
    var lianci = "";
    var curr = 0;
    //取得div层
    var $search = $('#search');
    //取得输入框JQuery对象
    var $searchInput = $search.find('#search-text');
    //关闭浏览器提供给输入框的自动完成
    $searchInput.attr('autocomplete', 'off');
    //创建自动完成的下拉列表,用于显示服务器返回的数据,插入在搜索按钮的后面,等显示的时候再调整位置
    var $autocomplete = $('<div></div>')
    .hide()
    .insertAfter('#submit');


    var getTxt1CursorPosition = function (id) {
    var oTxt1 = document.getElementById(id);
    var cursurPosition = -1;
    if (oTxt1.selectionStart) {//非IE浏览器
    cursurPosition = oTxt1.selectionStart;
    } else {//IE
    var range = document.selection.createRange();
    range.moveStart("character", -oTxt1.value.length);
    cursurPosition = range.text.length;
    }
    return cursurPosition;
    }
    var ThroughStartFindEnd = function (start) {
    if (start == "") {
    start = "0";
    }
    var end = start;
    var opt = ["+", "-", "*", "/", "(", ")", "="];
    for (var ii = parseInt(start) ; ii < $searchInput.val().length; ii++) {
    end = ii;
    if (opt.indexOf($searchInput.val()[ii]) > -1) {
    end = ii;
    break;
    }
    }

    return end;
    // if (start.toString() == "0") {
    // for (var ii = 0; ii< $searchInput.val().length; ii++) {
    // if (opt.indexOf($searchInput.val()[ii]) > -1) {
    // temp += "|";
    // } else {
    // temp += $searchInput.val()[ii];
    // }
    // }
    // fenci = temp.trimEnd('|');
    // var arr = fenci.split("|");
    // start = FindN_1Length(arr);
    // }
    //var end = start;
    //var opt = ["+", "-", "*", "/", "(", ")", "="];
    // for (var i = start; i < $searchInput.val().length; i++) {
    // if (opt.indexOf($searchInput.val()[i]) > -1) {
    // i--;
    // end = i;
    // return end;
    // break;
    // }
    // }
    // return $searchInput.val().length;
    }
    var FindN_1Length = function (arr) {
    var j = 0;
    for (var i = 0; i < arr.length; i++) {

    j += arr[i].length;
    if (i > 0) { j = j + 1; }
    }
    return j;
    }

    var zhihoudanci = "";
    var findLianci = function () {
    var tibu_danci = "";
    var danci = "";
    var newSearchInputVal = "";
    var start = 0;
    var aliveopt = [];
    var opt = ["+", "-", "*", "/", "(", ")", "="];
    var fenci = new Array();
    var temp = "";
    for (var i = 0; i < $searchInput.val().length; i++) {
    if (opt.indexOf($searchInput.val()[i]) > -1) {
    temp += "|";
    } else {
    temp += $searchInput.val()[i];
    }
    }
    fenci = temp.trimEnd('|');
    var arr = fenci.split("|");
    arr = $.grep(arr, function (n, i) {
    return n != "" && n != " ";
    });
    if (arr.length > 0) {
    tibu_danci = arr[0];
    }
    start = FindN_1Length(arr);
    var start_ = "";
    //if (selectionStart.toString() != "") {
    // start_ = selectionStart;
    //} else
    {
    start_ = getTxt1CursorPosition("search-text");
    }
    //if (zhihoudanci == "" || !zhihoudanci)
    //{
    zhihoudanci = $searchInput.val().substr(getTxt1CursorPosition("search-text"));
    //}
    var count = start;

    count = ThroughStartFindEnd(start_);
    temp = "";
    for (var i = 0; i < count; i++) {
    if (opt.indexOf($searchInput.val()[i]) > -1) {
    temp += "|";
    } else {
    temp += $searchInput.val()[i];
    }
    }
    fenci = temp.trimEnd('|');
    arr = fenci.split("|");
    arr = $.grep(arr, function (n, i) {
    return n != "" && n != " ";
    });
    //if (start_ == $searchInput.val().length)
    if (start_ ==count) {
    start_ = start_ - arr[arr.length - 1].length;
    }

    if (arr.length > 0) {
    cur_danci = arr[arr.length - 1];//$searchInput.val().substring(start_ - 1, count + 1);
    } else {
    cur_danci = tibu_danci;
    }
    if (opt.indexOf(cur_danci[0]) > -1) {
    for (var i = 1; i < cur_danci.length; i++) {
    danci += cur_danci[i];
    }
    }

    if (danci != "")
    cur_danci = danci;
    cur_danci = cur_danci.trimEnd('+').trimEnd('-').trimEnd("*").trimEnd('/').trimEnd('(').trimEnd(')').trimEnd('(').trimEnd(')');
    newSearchInputVal = $searchInput.val().substring(0, start_);//
    if (opt.indexOf(newSearchInputVal[newSearchInputVal.length - 1]) <= -1 && newSearchInputVal != "") {
    newSearchInputVal = $searchInput.val().substring(0, start_ - 1);//
    }
    if (opt.indexOf(newSearchInputVal[newSearchInputVal.length - 1]) <= -1) {
    newSearchInputVal = $searchInput.val().substring(0, start_ - 2)
    }
    if (newSearchInputVal == ""&&$searchInput.val().length>1) {
    newSearchInputVal = $searchInput.val().substring(0, start_+1);
    }
    return (newSearchInputVal);
    }
    //清空下拉列表的内容并且隐藏下拉列表区
    var clear = function () {
    $autocomplete.empty().hide();
    };
    $("#search-text").blur(function () {
    //$("#search-text").val("");
    });
    //注册事件,当输入框失去焦点的时候清空下拉列表并隐藏
    $searchInput.blur(function () {
    setTimeout(clear, 500);
    });
    //下拉列表中高亮的项目的索引,当显示下拉列表项的时候,移动鼠标或者键盘的上下键就会移动高亮的项目,想百度搜索那样
    var selectedItem = null;
    //timeout的ID
    var timeoutid = null;
    //设置下拉项的高亮背景
    var setSelectedItem = function (item) {
    //更新索引变量
    selectedItem = item;
    //按上下键是循环显示的,小于0就置成最大的值,大于最大值就置成0
    if (selectedItem < 0) {
    selectedItem = $autocomplete.find('li').length - 1;
    }
    else if (selectedItem > $autocomplete.find('li').length - 1) {
    selectedItem = 0;
    }
    //首先移除其他列表项的高亮背景,然后再高亮当前索引的背景
    $autocomplete.find('li').removeClass('highlight')
    .eq(selectedItem).addClass('highlight');
    };
    var ajax_request = function () {
    //ajax服务端通信
    $.ajax({
    'url': 'InputAutoCompelete.aspx', //服务器的地址
    'data': { 'search-text': cur_danci }, //参数
    'dataType': 'json', //返回数据类型
    'type': 'POST', //请求类型
    'success': function (data) {
    if (data.length) {
    //遍历data,添加到自动完成区
    $.each(data, function (index, term) {
    //创建li标签,添加到下拉列表中
    $('<li></li>').text(term).appendTo($autocomplete)
    .addClass('clickable')
    .hover(function () {
    //下拉列表每一项的事件,鼠标移进去的操作
    $(this).siblings().removeClass('highlight');
    $(this).addClass('highlight');
    selectedItem = index;
    }, function () {
    //下拉列表每一项的事件,鼠标离开的操作
    $(this).removeClass('highlight');
    //当鼠标离开时索引置-1,当作标记
    selectedItem = -1;
    })
    .click(function () {
    var $searchInputVal = $searchInput.val();
    var $newsearchInputVal = "";
    var fenci = findLianci();
    selectionStart = selectionEnd = "";
    $newsearchInputVal = fenci + term;
    $searchInput.val($newsearchInputVal + zhihoudanci);
    zhihoudanci = "";
    dbClick = false;
    //清空并隐藏下拉列表
    $autocomplete.empty().hide();
    });
    });//事件注册完毕
    //设置下拉列表的位置,然后显示下拉列表
    var ypos = $searchInput.position().top;
    var xpos = $searchInput.position().left;
    $autocomplete.css('width', $searchInput.css('width'));
    $autocomplete.css({ 'position': 'relative', 'left': xpos + "px", 'top': ypos + "px" });
    setSelectedItem(0);
    //显示下拉列表
    $autocomplete.show();
    }
    }
    });
    };
    //对输入框进行事件注册
    $searchInput
    .keyup(function (event) {
    //alert(222);
    //setTimeout(ajax_request, 100);
    //字母数字,退格,空格
    if (event.keyCode > 40 || event.keyCode == 8 || event.keyCode == 32) {
    //首先删除下拉列表中的信息
    $autocomplete.empty().hide();
    clearTimeout(timeoutid);
    findLianci();
    timeoutid = setTimeout(ajax_request, 100);
    }
    else if (event.keyCode == 38) {
    //上
    //selectedItem = -1 代表鼠标离开
    if (selectedItem == -1) {
    setSelectedItem($autocomplete.find('li').length - 1);
    }
    else {
    //索引减1
    setSelectedItem(selectedItem - 1);
    }
    event.preventDefault();
    }
    else if (event.keyCode == 40) {
    //下
    //selectedItem = -1 代表鼠标离开
    if (selectedItem == -1) {
    setSelectedItem(0);
    }
    else {
    //索引加1
    setSelectedItem(selectedItem + 1);
    }
    event.preventDefault();
    }
    })
    .keypress(function (event) {
    //enter键
    //findLianci();
    if (event.keyCode == 13) {
    //列表为空或者鼠标离开导致当前没有索引值
    if ($autocomplete.find('li').length == 0 || selectedItem == -1) {
    return;
    }
    //鼠标单击下拉列表的这一项的话,就将这一项的值添加到输入框中
    //ciku[ciku.length] = term;
    //for (var i = 0; i < ciku.length; i++) {
    // lianci = lianci + ciku[i];
    //}
    //$searchInput.val(lianci);
    //清空并隐藏下拉列表
    $autocomplete.empty().hide();
    // event.preventDefault();
    }
    })
    .keydown(function (event) {
    //esc键
    if (event.keyCode == 27) {
    $autocomplete.empty().hide();
    event.preventDefault();
    }
    }).change(function (event) {

    lianci = findLianci();
    ajax_request();
    }).on("dblclick", function () {
    dbClick = true;
    getSelectText2("search-text");
    //alert("zhihou="+$searchInput.val().substring(selectionEnd))
    zhihoudanci = $searchInput.val().substring(selectionEnd);
    //alert("start="+selectionStart+"end="+selectionEnd);
    }).on("select", function () {
    var id = "search-text";
    var t = document.getElementById(id);
    if (t.selectionStart != undefined && t.selectionEnd != undefined) {
    selectionStart = t.selectionStart;
    selectionEnd = t.selectionEnd;
    }
    });
    //注册窗口大小改变的事件,重新调整下拉列表的位置
    $(window).resize(function () {
    var ypos = $searchInput.position().top;
    var xpos = $searchInput.position().left;
    $autocomplete.css('width', $searchInput.css('width'));
    $autocomplete.css({ 'position': 'relative', 'left': xpos + "px", 'top': ypos + "px" });
    });
    });
    </script>
    </head>
    <body>
    <input type="button" id="btn1" name="btn1" value="选择文字" />
    <div id="search">
    <label for="search-text">请输入关键词</label>
    <input type="text" id="search-text" name="search-text" style=" 40%;" />
    <input type="button" id="clear_Content" name="clear_Content" value="清空" />
    <input type="button" id="submit" value="搜索" />
    </div>
    </body>
    </html>

    2.后台代码

    using HraWeb.Common;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text.RegularExpressions;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;

    namespace HraWeb
    {
    public partial class InputAutoCompelete : BasePage
    {
    // static readonly Regex paramRegex = new Regex(@"^()()$", RegexOptions.Compiled);
    protected void Page_Load(object sender, EventArgs e)

    {

    if (!string.IsNullOrEmpty(Request["search-text"]))
    {
    string[] words = {"资产负债","amani","abc","apple","abstract","an","bike","byebye",
    "beat","be","bing","come","cup","class","calendar","china" ,"+", "-", "*", "/","(",")","="};
    List<string> opration = new List<string>() { "+", "-", "*", "/" ,"="};
    string op = "";
    string key = Request["search-text"];
    char[] keyChar = key.ToCharArray();
    bool hasop = false;
    for (int i = 0; i < keyChar.Length; i++)
    {
    if (opration.Contains(keyChar[i].ToString()))
    {
    op = keyChar[i].ToString();
    keyChar[i] = '|';
    hasop = true;
    }
    }
    List<string> jsonList = new List<string>();
    List<string> newword = new List<string>();
    if (hasop)
    {
    newword = GetWord(keyChar);
    // key = newword[newword.Count - 1];
    if (opration.Contains(newword[newword.Count - 1]))
    {
    jsonList.Add(op);
    var json = Newtonsoft.Json.JsonConvert.SerializeObject(jsonList);
    HttpContext.Current.Response.Write(json);
    HttpContext.Current.Response.End();
    }
    }

    if (!hasop || key.Length == 1)

    {

    if (key.Length != 0)
    {

    for (int i = 0; i < words.Length; i++)
    {
    if (words[i].Contains(key))
    {
    jsonList.Add(words[i]);
    }
    }
    var json = Newtonsoft.Json.JsonConvert.SerializeObject(jsonList);
    HttpContext.Current.Response.Write(json);
    }
    HttpContext.Current.Response.End();
    }


    }
    }

    private List<string> GetWord(char[] keyChar)
    {
    List<string> newword = new List<string>();
    string word = "";
    List<string> keyCharList = new List<string>();
    keyChar.ToList().ForEach(c =>
    {
    keyCharList.Add(c.ToString());
    });
    for (int i = 0; i < keyCharList.Count; i++)
    {
    string c = keyCharList[i];
    if (c != "|")
    {
    word += c.ToString();
    if (i == keyCharList.Count - 1)
    {
    newword.Add(word);
    }
    }
    else
    {
    newword.Add(word.TrimEnd('|'));
    word = "";
    }
    }

    return newword;

    }
    }
    }

  • 相关阅读:
    sql优化-使用exists代替distinct
    count(*),count(1),count(c_bh)效率问题
    nulls last和null first
    连表更新
    postgresql-删除重复数据保留一条
    postgresql批量插入
    pg中join,left join的使用,将条件放到on和where后面的区别问题
    pg关于not in和not exists的使用
    postgresql关于in和exists使用
    postgresql无序uuid性能测试
  • 原文地址:https://www.cnblogs.com/kexb/p/5078461.html
Copyright © 2011-2022 走看看