JavaScript输入邮箱自动提示实例代码

 这篇文章主要介绍了JavaScript输入邮箱自动提示实例代码,有需要的朋友可以参考一下

本来想把之前对artTemplate源码解析的注释放上来分享下,不过隔了一年,找不到了,只好把当时分析模板引擎原理后,自己尝试
 
写下的模板引擎与大家分享下,留个纪念,记得当时还对比了好几个模板引擎来着。
 
这里所说的js的模板引擎,用的是原生的javascript语法,所以很类似php的原生模板引擎。
 
 
 
前端模板引擎的作用?
 
1. 可以让前端开发更简单,不需要为了生成一个dom结构而使用+运算符去拼接字符串,而只需要一个元素的(里面的html模板),或者一个变量(存储着模板),或者  一个模板文件
 
2. 易于维护,减少耦合,假使你的dom结构变化了,不需要更改逻辑代码,而只需要更改对应的模板(文件)
 
3. 可以缓存,如果你的模板是一个类似.tpl的文件,那么完全可以用浏览器去加载,并且还存下来。说到.tpl文件,可以做的不仅仅是缓存了,你还可以做到通过模块加载器
 
    将.tpl作为一个模块,那就可以按需加载文件,不是更省宽带,加快页面速度吗?
 
4. 等等等
 
 
 
前端模板引擎的原理?
 
原理很简单就是 对象(数据)+ 模板(含有变量) -> 字符串(html)
 
 
 
前端模板引擎的如何实现?
 
通过解析模板,根据词法,将模板转换成一个函数,然后通过调用该函数,并传递对象(数据),输出字符串(html)
 
(当然,具体的还要看代码的)
 
就像这样:
 
代码如下:
var tpl = 'i am <%= name%>, <%= age=> years old'; // <%=xxx>% 词法,标记为变量
 
var obj = {
    name : 'lovesueee' ,
    age : 24
};
var fn = Engine.compile(tpl); // 编译成函数
 
var str = fn(obj);   // 渲染出字符串        
 
 
例子:
 
代码如下:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>ice demo</title>
<script src="/javascripts/jquery/jquery-1.7.2.js"></script>
<script src="/javascripts/ice/ice.js"></script>
<body>
    <div id="content"></div>
</body>
 
<script type="text/html" id="tpl">
    <div>here is the render result:</div>
    <%  = this.title() ;%>
    <table border=1>
    <% for(var i=0,tl = this.trs.length,tr;i<tl;i++){  %>
        <%
            tr = this.trs[i];
            if (tr.sex === "女") {
        %>
        <tr>
        <td><%= tr.name;; %></td> <td><%= tr.age; %></td> <td><%= tr.sex || "男" %></td>
        </tr>
        <% } %>
    <% } %>
    </table>
    <img src="<%= this.href %>">
    <%= this.include('tpl2',this); %>
</script>
<script type="text/html" id="tpl2">
    <div>here is the render result:</div>
    <%  = this.print('Welcome to Ice Template') ;%>
    <table border=1>
    <% for(var i=0,tl = this.trs.length,tr;i<tl;i++){  %>
        <%
            tr = this.trs[i];
            if (tr.sex === "男") {
        %>
        <tr>
        <td><%= tr.name;; %></td> <td><%= tr.age; %></td> <td><%= tr.sex || "男" %></td>
        </tr>
        <% } %>
    <% } %>
    </table>
    <img src="<%= this.href %>">
 
</script>
<script>
    var trs = [
        {name:"隐形杀手",age:29,sex:"男"},
        {name:"索拉",age:22,sex:"男"},
        {name:"fesyo",age:23,sex:"女"},
        {name:"恋妖壶",age:18,sex:"男"},
        {name:"竜崎",age:25,sex:"男"},
        {name:"你不懂的",age:30,sex:"女"}
    ]
 
    // var html = ice("tpl",{
    //     trs: trs,
    //     href: "type4.jpg"
    // },{
    //     title: function(){
    //         return "<p>这是使用视图helper输出的代码片断</p>"
    //     }
    // });
    var elem = document.getElementById('tpl');
    var tpl = elem.innerHTML;
 
    var html = ice(tpl,{
        trs: trs,
        href: "type4.jpg"
    },{
        title: function(){
            return "<p>这是使用视图helper输出的代码片断</p>"
        }
    });
    console.log(html);
    $("#content").html(html);
 
</script>
</html>
 
 
 
 
简单的实现:
 
 代码如下:
(function (win) {
 
    // 模板引擎路由函数
    var ice = function (id, content) {
        return ice[
            typeof content === 'object' ? 'render' : 'compile'
        ].apply(ice, arguments);
    };
 
 
    ice.version = '1.0.0';
 
    // 模板配置
    var iConfig = {
        openTag  : '<%',
        closeTag : '%>'
    };
 
 
    var isNewEngine = !!String.prototype.trim;
 
    // 模板缓存
    var iCache = ice.cache = {};
 
    // 辅助函数
    var iHelper = {
        include : function (id, data) {
            return iRender(id, data);
        },
        print : function (str) {
            return str;
        }
    };
 
    // 原型继承
    var iExtend = Object.create || function (object) {
        function Fn () {};
        Fn.prototype = object;
        return new Fn;
    };
 
    // 模板编译
    var iCompile = ice.compile = function (id, tpl, options) {
 
        var cache = null;
 
        id && (cache = iCache[id]);
 
        if (cache) {
            return cache;
        }
 
        // [id | tpl]
        if (typeof tpl !== 'string') {
 
            var elem = document.getElementById(id);
 
            options = tpl;
 
            if (elem) {
                // [id, options]
                options = tpl;
                tpl = elem.value || elem.innerHTML;
 
            } else {
                //[tpl, options]
                tpl = id;
                id = null;
            }
        }
 
        options = options || {};
        var render  = iParse(tpl, options);
 
        id && (iCache[id] = render);
 
        return render;
    };
 
 
    // 模板渲染
    var iRender = ice.render = function (id, data, options) {
 
        return iCompile(id, options)(data);
    };
 
 
    var iForEach = Array.prototype.forEach ?
        function(arr, fn) {
            arr.forEach(fn)
        } :
        function(arr, fn) {
            for (var i = 0; i < arr.length; i++) {
                fn(arr[i], i, arr)
            }
        };
 
 
    // 模板解析
    var iParse = function (tpl, options) {
 
        var html = [];
 
        var js = [];
 
        var openTag = options.openTag || iConfig['openTag'];
 
        var closeTag = options.closeTag || iConfig['closeTag'];
 
        // 根据浏览器采取不同的拼接字符串策略
        var replaces = isNewEngine
            ?["var out='',line=1;", "out+=", ";", "out+=html[", "];", "this.result=out;"]
            : ["var out=[],line=1;",  "out.push(", ");", "out.push(html[", "]);", "this.result=out.join('');"];
 
        // 函数体
        var body = replaces[0];
 
        iForEach(tpl.split(openTag), function(val, i) {
 
            if (!val) {
                return;
            }
 
            var parts = val.split(closeTag);
 
            var head = parts[0];
 
            var foot = parts[1];
 
            var len = parts.length;
            // html
            if (len === 1) {
                body += replaces[3] + html.length + replaces[4];
                html.push(head);
 
            } else {
 
                if (head ) {
                    // code
                    // 去除空格
                    head = head
                        .replace(/^s+|s+$/g, '')
                        .replace(/[nr]+s*/, '')
 
 
                    // 输出语句
                    if (head.indexOf('=') === 0) {
                        head = head.substring(1).replace(/^[s]+|[s;]+$/g, '');
 
                        body += replaces[1] + head + replaces[2];
                    } else {
                        body += head;
                    }
 
                    body += 'line+=1;';
                    js.push(head);
                }
                // html
                if (foot) {
                    _foot = foot.replace(/^[nr]+s*/g, '');
                    if (!_foot) {
                        return;
                    }
                    body += replaces[3] + html.length + replaces[4];
                    html.push(foot);
                }
            }
        });
 
        body = "var Render=function(data){ice.mix(this, data);try{"
            + body
            + replaces[5]
            + "}catch(e){ice.log('rend error : ', line, 'line');ice.log('invalid statement : ', js[line-1]);throw e;}};"
            + "var proto=Render.prototype=iExtend(iHelper);"
            + "ice.mix(proto, options);"
            + "return function(data){return new Render(data).result;};";
 
        var render = new Function('html', 'js', 'iExtend', 'iHelper', 'options', body);
 
        return render(html, js, iExtend, iHelper, options);
    };
 
    ice.log = function () {
        if (typeof console === 'undefined') {
            return;
        }
 
        var args = Array.prototype.slice.call(arguments);
 
        console.log.apply && console.log.apply(console, args);
 
    };
 
    // 合并对象
    ice.mix = function (target, source) {
        for (var key in source) {
            if (source.hasOwnProperty(key)) {
                target[key] = source[key];
            }
        }
    };
 
    // 注册函数
    ice.on = function (name, fn) {
        iHelper[name] = fn;
    };
 
    // 清除缓存
    ice.clearCache = function () {
        iCache = {};
    };
 
    // 更改配置
    ice.set = function (name, value) {
        iConfig[name] = value;
    };
 
    // 暴露接口
    if (typeof module !== 'undefined' && module.exports) {
        module.exports = template;
    } else {
        win.ice = ice;
    }
 
})(window);
 

时间: 2025-01-07 07:59:58

JavaScript输入邮箱自动提示实例代码的相关文章

JavaScript输入邮箱自动提示实例代码_javascript技巧

本来想把之前对artTemplate源码解析的注释放上来分享下,不过隔了一年,找不到了,只好把当时分析模板引擎原理后,自己尝试 写下的模板引擎与大家分享下,留个纪念,记得当时还对比了好几个模板引擎来着. 这里所说的js的模板引擎,用的是原生的javascript语法,所以很类似php的原生模板引擎.   前端模板引擎的作用? 1. 可以让前端开发更简单,不需要为了生成一个dom结构而使用+运算符去拼接字符串,而只需要一个元素的(里面的html模板),或者一个变量(存储着模板),或者 一个模板文件

js输入框邮箱自动提示功能代码实现_javascript技巧

同理 此插件不需要任何html标签,只需要一个输入框 有相对应的class类名就ok 且父级有个class类名,其他的都不需要.内部的HTML代码都是自动生成的. HTML代码如下: 复制代码 代码如下: <div class="parentCls">    <input type="text" class="inputElem"> </div> 其实上面的div标签都可以不需要 只需要在input输入框 且父

Win 10开发输入搜索自动提示下拉控件(AutoSuggestBox)实例

AutoSuggestBox控件与TextBox控件相似,但,AutoSuggestBox控件可以提供一个下拉列表,用户可以从弹出的下拉列表中选择一个项,并把被选项的内容显示在输入框上.就类似于搜索引擎的输入页面. 在使用AutoSuggestBox控件时,要注意它有几个重要事件. a.当下拉列表中的项被选择后,会发生SuggestionChosen事件. b.当在QuerySubmitted的下拉列表中做出选择后,或者单击输入框右边的查找图标(如果有,需自行设置)会提交输入的文本,这时候会发生

javascript suggest效果 自动完成实现代码分享_javascript技巧

首先,用到的框架当然是我的框架mass Framework,当然你用其他框架也可以,如jQuery,没有什么复杂的东西.只要弄懂原理,一下子就能搞出来.想必,以后你们工作也遇到做搜索框的活儿. 由于本人没有后端,因此取用一个对象作为本地数据库.而我现在要做的,其实远远比suggest高级,类似IDE的语法提示的东西.当前成品已放到github上. 好了,我们动手吧.首先是结构层,装了FF的同学可以在百度首页查看源码,当输入几个字母时,会动态生成了那些HTML.不过怎么也好,其成就是一个DIV放到

JavaScript 实现鼠标拖动元素实例代码

 这篇文章主要介绍了JavaScript 实现鼠标拖动元素实例代码,需要的朋友可以参考下 一.前言   最开始实现鼠标拖动元素的目的就是在一个页面上拖动很多小圆点,用于固定定位,然后在复制HTML,粘贴在页面的开发代码中,就是这么一个功能,实现了很多遍,都没有做好,不得已采用了jQuery.fn.draggable插件,在接触一些资料和别人的思路,今天终于把这个拖动功能给完善了,下面就来看看它的实现     二.设计思路   在拖动元素上绑定鼠标按下事件,在文档对象中绑定鼠标移动,鼠标弹起事件:

JavaScript实现跑马灯抽奖活动实例代码解析与优化(二)_javascript技巧

在上篇文章给大家介绍了JavaScript实现跑马灯抽奖活动实例代码解析与优化(一),既然是要编写插件.那么叫做"插件"的东西肯定是具有的某些特征能够满足我们平时开发的需求或者是提高我们的开发效率.那么叫做插件的东西应该具有哪些基本特征呢?让我们来总结一下: 1.JavaScript 插件一些基本特征: 配置一定要简单 插件中定义的变量不污染全局变量: 同一段代码可以在不同的地方复用: 用户可以自定义自己功能参数: 具有销毁变量和参数的功能: 如果按照以上的几个特征来写插件的话,我们可

文本框输入邮箱自动联想补全

文本框输入邮箱自动联想补全 <!DOCTYPE html> <html> <head> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <title&g

javascript实现json页面分页实例代码

 这篇文章主要介绍了javascript实现json页面分页实例代码,需要的朋友可以参考下 下午有个朋友问json 数据怎么分页 就捣鼓了一个东东出来    下面直接代码: 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns

eclipse中js提示-Eclipse如何自动提示js代码

问题描述 Eclipse如何自动提示js代码 之前用的是myeclipse,现在公司要用eclipse,之前在写js时,全部时靠自己的记忆来写js代码, 毕竟js代码过多,一些标签不可能都记住,每次要写还要百度,很不方便,我就百度找了下 有没有方法让eclipse自动提示js代码,在网上找了一大堆,看到许多一模一样的帖子,不用 安装插件就可以提示java.js.html代码,我照着他们的方法配置了,然而并没有什么卵用! 大家能不能支支招,是什么原因,有没有什么其他比较好的办法解决这个问题 解决方