一个简单易懂的javascrip selection&range小案例
在制作富文本编辑器,尤其是在制作以div元素为编辑器区域时,当鼠标离开编辑区域以后会失去焦点,失去选区,这时候就要通过selection&range来重新设置选区。【以下代码尚未考虑IE低版本,请在现代浏览器下测试学习】
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>range</title>
<style type="text/css">
#edit{
width: 100%;
height: 300px;
border: 1px solid #ccc;
}
</style>
</head>
<body>
<div contenteditable="true" id="edit">
<p>通过一个富文本编辑器,学习JavaScript!</p>
</div>
<div id="button">button</div>
<script type="text/javascript"> var edit = document.getElementById('edit');
var button = document.getElementById('button'); edit.addEventListener('mouseup', function() {
saveSelection();
}); button.addEventListener('click', function() {
restoreSelection();
document.execCommand('underline', false, null);
saveSelection();
}); function saveSelection() {
selection = document.getSelection();
save = selection.getRangeAt(0); } function restoreSelection() {
var selection = window.getSelection(); if(selection.rangeCount > 0) {
selection.removeAllRanges();
} var range = document.createRange();
selection.addRange(save);
} </script>
</body>
</html>
一个简单易懂的javascrip selection&range小案例的更多相关文章
- Servlet----------用servlet写一个“网站访问量统计“的小案例
		
package cn.example; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.Ser ...
 - Vue 自定义一个插件的用法、小案例及在项目中的应用
		
1.开发插件 install有两个参数,第一个是Vue构造器,第二个参数是一个可选的选项对象 MyPlugin.install = function (Vue, options) { // 1 ...
 - ES6基础与解构赋值(高颜值弹框小案例!)
		
let只作用在当前块级作用域内使用let或者const声明的变量,不能再被重新声明let不存在`变量提升` console.log(dad); var dad = '我是爸爸!';//预定义undef ...
 - (24/24) webpack小案例--自己动手用webpack构建一个React的开发环境
		
通过前面的学习,对webpack有了更深的认识,故此节我们就利用前面相关知识自己动手用webpack构建一个React的开发环境,就算是一个小案例吧. 注:此处使用的开发工具是Webstorm. 1. ...
 - 一个ssm综合小案例-商品订单管理----写在前面
		
学习了这么久,一直都是零零散散的,没有把知识串联起来综合运用一番 比如拦截器,全局异常处理,json 交互,RESTful 等,这些常见技术必须要掌握 接下来呢,我就打算通过这么一个综合案例把这段时间 ...
 - Python:通过一个小案例深入理解IO多路复用
		
通过一个小案例深入理解IO多路复用 假如我们现在有这样一个普通的需求,写一个简单的爬虫来爬取校花网的主页 import requests import time start = time.time() ...
 - 一个简单的Maven小案例
		
Maven是一个很好的软件项目管理工具,有了Maven我们不用再费劲的去官网上下载Jar包. Maven的官网地址:http://maven.apache.org/download.cgi 要建立一个 ...
 - 机械表小案例之transform的应用
		
这个小案例主要是对transform的应用. 时钟的3个表针分别是3个png图片,通过setInterval来让图片转动.时,分,秒的转动角度分别是30,6,6度. 首先,通过new Date函数获取 ...
 - [转载]再谈百度:KPI、无人机,以及一个必须给父母看的案例
		
[转载]再谈百度:KPI.无人机,以及一个必须给父母看的案例 发表于 2016-03-15 | 0 Comments | 阅读次数 33 原文: 再谈百度:KPI.无人机,以及一个必须 ...
 
随机推荐
- iptables防火墙详解
			
iptables常用命令 iptables -nv -L 查看iptables列表 iptables -F 清空iptables规则 iptables-save > /etc/sysconfig ...
 - 笨方法学python--数字和数学计算
			
1 数学运算符号 + plus 加号 - minus 减号 / slash 除法 * asterisk 乘法 % percent 模除 求余 < less than 小于号 > great ...
 - 【HDU 5833】Zhu and 772002(异或方程组高斯消元讲解)
			
题目大意:给出n个数字a[],将a[]分解为质因子(保证分解所得的质因子不大于2000),任选一个或多个质因子,使其乘积为完全平方数.求其方法数. 学长学姐们比赛时做的,当时我一脸懵逼的不会搞……所以 ...
 - Hadoop学习笔记—5.自定义类型处理手机上网日志
			
转载自http://www.cnblogs.com/edisonchou/p/4288737.html Hadoop学习笔记—5.自定义类型处理手机上网日志 一.测试数据:手机上网日志 1.1 关于这 ...
 - android 图片拍照图片旋转的处理方式
			
第一种:String str=path; /** * 读取图片属性:旋转的角度 * * @param path * 图片绝对路径 * @return degree旋转的角度 */ private vo ...
 - 2016中国大学生程序设计竞赛 - 网络选拔赛 1004	Danganronpa
			
Problem Description Chisa Yukizome works as a teacher in the school. She prepares many gifts, which ...
 - Issue 5158:	Modal dialog present (UnexpectedAlertOpen) issue in IE (Similar issue like 3360)
			
https://code.google.com/p/selenium/issues/detail?id=5158 Reported by mailtopa...@gmail.com, Feb 13 ...
 - java监控函数执行时间
			
java监控函数执行时间 http://blog.csdn.net/ycg01/article/details/1467542 java监控函数执行时间 标签: javathreadclassstri ...
 - Android media媒体库分析之:MediaProvider
			
在做Android媒体应用程序时(Audio.Image.Video)需要对Android的媒体提供者(MediaProvider)做详细的分析,下面记录一下我的收获: 一.获取MediaProvid ...
 - stock 财务 指标
			
净资产收益率:"不能比利率低"每股收益是烟幕弹 有一点需要提请大家注意,观察净资产收益率至少要看过去三年的指标,如果公司没有经过大的资产重组,最好看看自其上市以来每一年的净资产收益 ...