JS代码实用代码实例(输入框监听,点击显示点击其他地方消失,文件本地预览上传)
前段时间写前端,遇到一些模块非常有用,总结以备后用
一.input框字数监听
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <input type="text" name="wxChoiceInfo.infoTitle" id="wxChoiceInfoInfoTitle" size="120" onkeyup="countNum(this)"/>
- <div id="countNum" style="color: blue">还可输入<span id="num">140</span>个汉字</div>
- <script src="static/js/jquery-1.12.4.js"></script>
- <script>
- function countNum(e){
- var value=$(e).val();
- var cArr = value.match(/([\u0391-\uffe5])/ig); // 返回中文的字符
- var num=Math.floor((420-value.length-2*(cArr == null ? 0 : cArr.length))/3);
- $("#num").text(num);
- if(num>=0){
- $("#countNum").css({"color": "#FBBC05"});
- }else{
- $("#countNum").css({"color": "#EA4335"});
- }
- }
- </script>
- </body>
- </html>
二.点输入框显示,点击页面其他地方隐藏功能
- <!DOCTYPE HTML>
- <html>
- <head>
- <meta charset="utf-8">
- <title>无标题文档</title>
- <style>
- #div1 {width:400px; height:300px; background:#CCC; display:none;}
- </style>
- <script>
- window.onload=function ()
- {
- var oBtn=document.getElementById('btn1');
- var oDiv=document.getElementById('div1');
- oBtn.onclick=function (ev)
- {
- var oEvent=ev||event;
- oDiv.style.display='block';
- //alert('按钮被点击了');
- oEvent.cancelBubble=true;
- };
- document.onclick=function ()
- {
- oDiv.style.display='none';
- //alert('document被点击了');
- };
- };
- </script>
- </head>
- <body>
- <input id="btn1" type="button" value="显示" />
- <div id="div1">
- </div>
- <div id="div2">
- </div>
- </body>
- </html>
三.表情框
- // QQ表情插件
- (function($){
- $.fn.qqFace = function(options){
- var defaults = {
- id : 'facebox',
- path : 'face/',
- assign : 'content',
- tip : 'em_'
- };
- var option = $.extend(defaults, options);
- var assign = $('#'+option.assign);
- var id = option.id;
- var path = option.path;
- var tip = option.tip;
- if(assign.length<=0){
- alert('缺少表情赋值对象。');
- return false;
- }
- $(this).click(function(e){
- var strFace, labFace;
- if($('#'+id).length<=0){
- strFace = '<div id="'+id+'" style="position:absolute;display:none;z-index:1000;" class="qqFace">' +
- '<table border="0" cellspacing="0" cellpadding="0"><tr>';
- for(var i=1; i<=75; i++){
- labFace = '['+tip+i+']';
- strFace += '<td><img src="'+path+i+'.gif" onclick="$(\'#'+option.assign+'\').setCaret();$(\'#'+option.assign+'\').insertAtCaret(\'' + labFace + '\');" /></td>';
- if( i % 15 == 0 ) strFace += '</tr><tr>';
- }
- strFace += '</tr></table></div>';
- }
- $(this).parent().append(strFace);
- var offset = $(this).position();
- var top = offset.top + $(this).outerHeight();
- $('#'+id).css('top',top);
- $('#'+id).css('left',offset.left);
- $('#'+id).show();
- e.stopPropagation();
- });
- $(document).click(function(){
- $('#'+id).hide();
- $('#'+id).remove();
- });
- };
- })(jQuery);
- jQuery.extend({
- unselectContents: function(){
- if(window.getSelection)
- window.getSelection().removeAllRanges();
- else if(document.selection)
- document.selection.empty();
- }
- });
- jQuery.fn.extend({
- selectContents: function(){
- $(this).each(function(i){
- var node = this;
- var selection, range, doc, win;
- if ((doc = node.ownerDocument) && (win = doc.defaultView) && typeof win.getSelection != 'undefined' && typeof doc.createRange != 'undefined' && (selection = window.getSelection()) && typeof selection.removeAllRanges != 'undefined'){
- range = doc.createRange();
- range.selectNode(node);
- if(i == 0){
- selection.removeAllRanges();
- }
- selection.addRange(range);
- } else if (document.body && typeof document.body.createTextRange != 'undefined' && (range = document.body.createTextRange())){
- range.moveToElementText(node);
- range.select();
- }
- });
- },
- setCaret: function(){
- //if(!$.browser.msie) return;
- var initSetCaret = function(){
- var textObj = $(this).get(0);
- //textObj.caretPos = document.selection.createRange().duplicate();
- };
- $(this).click(initSetCaret).select(initSetCaret).keyup(initSetCaret);
- },
- insertAtCaret: function(textFeildValue){
- var textObj = $(this).get(0);
- if(document.all && textObj.createTextRange && textObj.caretPos){
- var caretPos=textObj.caretPos;
- caretPos.text = caretPos.text.charAt(caretPos.text.length-1) == '' ?
- textFeildValue+'' : textFeildValue;
- } else if(textObj.setSelectionRange){
- var rangeStart=textObj.selectionStart;
- var rangeEnd=textObj.selectionEnd;
- var tempStr1=textObj.value.substring(0,rangeStart);
- var tempStr2=textObj.value.substring(rangeEnd);
- textObj.value=tempStr1+textFeildValue+tempStr2;
- textObj.focus();
- var len=textFeildValue.length;
- textObj.setSelectionRange(rangeStart+len,rangeStart+len);
- textObj.blur();
- }else{
- textObj.value+=textFeildValue;
- }
- }
- });
qqface.js
- <!doctype html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
- <title>qqFace</title>
- <link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
- <link rel="stylesheet" href="css/reset.css">
- <style>
- .comment{width:680px; margin:20px auto; position:relative; background:#fff; padding:20px 50px 50px; border:1px solid #DDD; border-radius:5px;}
- .comment h3{height:28px; line-height:28px}
- .com_form{width:100%; position:relative}
- .input{width:99%; height:60px; border:1px solid #ccc}
- .com_form p{height:28px; line-height:28px; position:relative; margin-top:10px;}
- span.emotion{width:42px; height:20px;}
- span.emotion:hover{background-position:2px -28px}
- .qqFace{margin-top:4px;background:#fff;padding:2px;border:1px #dfe6f6 solid;}
- .qqFace table td{padding:0px;}
- .qqFace table td img{cursor:pointer;border:1px #fff solid;}
- .qqFace table td img:hover{border:1px #0066cc solid;}
- #show{width:770px; margin:20px auto; background:#fff; padding:5px; border:1px solid #DDD; vertical-align:top;}
- .sub_btn {
- position:absolute; right:0px; top:0;
- display: inline-block;
- zoom: 1; /* zoom and *display = ie7 hack for display:inline-block */
- *display: inline;
- vertical-align: baseline;
- margin: 0 2px;
- outline: none;
- cursor: pointer;
- text-align: center;
- font: 14px/100% Arial, Helvetica, sans-serif;
- padding: .5em 2em .55em;
- text-shadow: 0 1px 1px rgba(0,0,0,.6);
- -webkit-border-radius: 3px;
- -moz-border-radius: 3px;
- border-radius: 3px;
- -webkit-box-shadow: 0 1px 2px rgba(0,0,0,.2);
- -moz-box-shadow: 0 1px 2px rgba(0,0,0,.2);
- box-shadow: 0 1px 2px rgba(0,0,0,.2);
- color: #e8f0de;
- border: solid 1px #538312;
- background: #64991e;
- background: -webkit-gradient(linear, left top, left bottom, from(#7db72f), to(#4e7d0e));
- background: -moz-linear-gradient(top, #7db72f, #4e7d0e);
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#7db72f', endColorstr='#4e7d0e');
- }
- .sub_btn:hover {
- background: #538018;
- background: -webkit-gradient(linear, left top, left bottom, from(#6b9d28), to(#436b0c));
- background: -moz-linear-gradient(top, #6b9d28, #436b0c);
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#6b9d28', endColorstr='#436b0c');
- }
- </style>
- </head>
- <body>
- <div id="show"></div>
- <div class="comment">
- <div class="com_form">
- <textarea class="input" id="saytext" ></textarea>
- <p><input type="button" class="sub_btn" value="提交"><span class="emotion">表情</span></p>
- </div>
- </div>
- <script src="js/jquery.min.js"></script>
- <script type="text/javascript" src="js/jquery.qqFace.js"></script>
- <script type="text/javascript">
- $(function(){
- $('.emotion').qqFace({
- id : 'facebox',
- assign:'saytext',
- path:'arclist/' //表情存放的路径
- });
- $(".sub_btn").click(function(){
- var str = $("#saytext").val();
- $("#show").html(replace_em(str));
- });
- });
- //查看结果
- function replace_em(str){
- str = str.replace(/\</g,'<');
- str = str.replace(/\>/g,'>');
- str = str.replace(/\n/g,'<br/>');
- str = str.replace(/\[em_([0-9]*)\]/g,'<img src="arclist/$1.gif" border="0" />');
- return str;
- }
- </script>
- </body>
- </html>
四. 文件本地预览上传
- function handleFileSelect(evt) {
- var files = evt.target.files;
- // Loop through the FileList and render image files as thumbnails.
- for (var i = 0, f; f = files[i]; i++) {
- // Only process image files.
- if (!f.type.match('image.*')) {
- continue;
- }
- var reader = new FileReader();
- // Closure to capture the file information.
- reader.onload = (function(theFile) {
- return function(e) {
- // Render thumbnail.
- var span = document.createElement('span');
- span.innerHTML =
- [
- '<img style="height: 75px; border: 1px solid #000; margin: 5px" src="',
- e.target.result,
- '" title="', escape(theFile.name),
- '"/>'
- ].join('');
- document.getElementById('list').insertBefore(span, null);
- };
- })(f);
- // Read in the image file as a data URL.
- reader.readAsDataURL(f);
- }
- }
- document.getElementById('files').addEventListener('change', handleFileSelect, false);
fileLocalUpload.js
- <input type="file" id="files" multiple />
- <output id="list"></output>
JS代码实用代码实例(输入框监听,点击显示点击其他地方消失,文件本地预览上传)的更多相关文章
- 对百度WebUploader的二次封装,精简前端代码之图片预览上传(两句代码搞定上传)
前言 本篇文章上一篇: 对百度WebUploader开源上传控件的二次封装,精简前端代码(两句代码搞定上传) 此篇是在上面的基础上扩展出来专门上传图片的控件封装. 首先我们看看效果: 正文 使用方式同 ...
- js获取base64格式图片预览上传并用php保存到本地服务器指定文件夹
html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...
- Ext JS 5的声明式事件监听
在前文<在Ext JS 5使用ViewControllers>中,简单的介绍了Ext JS 5的一项重要改进——声明式事件监听.在本文,将深度探讨如何使用声明式事件监听啦简化应用程序的视图 ...
- js和jquery实现页面滚动监听
js和jquery实现页面滚动监听 一.总结 一句话总结:onscroll方法和监听页面元素的高度都可以实现滚动监听. 1.onscroll方法实现滚动监听的核心代码是什么? <body ons ...
- Linux hostname对Oracle实例以及监听的影响
在Linux平台中,对hostname的修改,是否对ORACLE数据库实例或监听进程有影响呢?如果有影响,又要如何解决问题呢?另外/etc/hosts下相关内容的修改,是否也会影响实例或监听呢?这里涉 ...
- [html5+java]文件异步读取及上传核心代码
html5+java 文件异步读取及上传关键代码段 功能: 1.多文件文件拖拽上传,file input 多文件选择 2.html5 File Api 异步FormData,blob上传,图片显示 3 ...
- 【Azure 应用服务】App Service 在使用GIt本地部署,上传代码的路径为/home/site/repository,而不是站点的根目录/home/site/wwwroot。 这个是因为什么?
问题描述 App Service 在使用GIt本地部署,上传代码的路径为/home/site/repository,而不是站点的根目录/home/site/wwwroot. 这个是因为什么? 并且通过 ...
- 【转】Android开发20——单个监听器监听多个按钮点击事件
原文网址:http://woshixy.blog.51cto.com/5637578/1093936 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律 ...
- 如何使用Git建立本地仓库并上传代码到GitHub
使用Git建立本地仓库并上传代码到GitHub 工具/原料 电脑安装git客户端.注册github账号并登陆 方法/步骤 到本地项目文件夹右键选择git bash here 输入个人信 ...
随机推荐
- 浅谈JAVA集合框架
浅谈JAVA集合框架 Java提供了数种持有对象的方式,包括语言内置的Array,还有就是utilities中提供的容器类(container classes),又称群集类(collection cl ...
- javascript_core_04之数组API
1.数组API——splice: ①删除:var deletes=arr.splice(starti,n):删除starti位置开始的n个,返回删除元素组成的临时数组: ②插入:arr.splice( ...
- CCNA网络工程师学习进程(1)网络的基本概述
在互联网快速发展的今天,了解互联网成为一项必须的技能,因此在学习编程之余学习如何配置网络还是很有必要的. 本系列博客计划分为三个部分,包括思科CCNA.CCNP和华为的网络工程师认证有关的知识 ...
- JS原生第二篇 (帅哥)
1.1 Javascript 作用 1. 网页特效 2. 用户交互 3. 表单验证 Js 就是可以用来控制 结构 和 样式 . 1.2 体验js 认识常用的三个输出语句. 都属于 ...
- ASP.NET MVC 4使用PagedList.Mvc分页
ASP.NET MVC中进行分页的方式有多种,在NuGet上有提供使用PagedList.PagedList.Mvc进行分页. 1. 通过NuGet引用PagedList.Mvc 在安装引用Paged ...
- Symfony2模版引擎使用说明手册
一.基本使用 {{ demo }}输出一个demo变量; {% func %}通常是包含一个twig函数例如 for; 举个for循环的例子: {% for i in 0..10 %} <em& ...
- Android线程之Looper
之前已经为大家奉献了关于Handler和Message的使用,本篇我们来了解一下Handler内部的具体使用,本篇主要探讨Looper的在处理Handler的消息机制中起的重要作用,我们知道我们在子线 ...
- Mybatis之Oracle增删查改示例--转
http://blog.csdn.net/bingjie1217/article/details/21088431?utm_source=tuicool&utm_medium=referral ...
- 决战JS
经过这几日的学习,测试和摸索,算是了解了一些关于javascript 的相关知识吧.学习过程中做出了一些小DEMO,现总结一下实现这些DEMO的基本思路,如有不妥或更为简便的方法,还希望大神拍砖,共同 ...
- SQL Server安全(10/11):行级别安全(Row-Level Security)
在保密你的服务器和数据,防备当前复杂的攻击,SQL Server有你需要的一切.但在你能有效使用这些安全功能前,你需要理解你面对的威胁和一些基本的安全概念.这篇文章提供了基础,因此你可以对SQL Se ...