简单的弹出拖拽窗口(二)

接上文 简单的弹出拖拽窗口(一)

下面开始具体分析代码部分:

首先我们先确认下结构:

悬浮窗口:初始不可见。包括标题栏和内容栏,标题栏内有标题和关闭按钮。

遮罩层:初始不可见。用于设置弹出悬浮窗口时的半透明背景,

按钮:用于点击弹出悬浮窗口。

下面进行详细解释

1.要让窗口能自由移动,那么窗口的定位(position)应该采用绝对定位(absolute);

/*登录浮层组件*/

 1  .popup{
 2     display:none;                                              /*初始隐藏*/
 3     width: 380px;
 4     height: auto;                                              /*高度自由,因为不确定,内容多少。*/
 5     border: 1px solid #D5D5D5;
 6     background: #fff;                                          /*窗口内容不透明,背景为白色*/
 7     box-shadow: 0 0 3px rgba(0, 0, 0, 0.25);
 8     -moz-box-shadow:0 0 3px rgba(0, 0, 0, 0.25);
 9     -webkit-box-shadow:0 0 3px rgba(0, 0, 0, 0.25);             /*内容窗口带阴影*/
10     border-radius: 8px;                                         /* 所有角都使用半径为8px的圆角,此属性为CSS3标准属性 */
11     -moz-border-radius: 8px;                                    /* Mozilla浏览器的私有属性 */
12     -webkit-border-radius:8px;                                  /* Webkit浏览器的私有属性 */ /*窗口圆角*/
13     position: absolute;
14     top: 100px;
15     left: 100px;                                               /*绝对定位*/
16     z-index: 9000;
17     }

2.给窗口添加标题栏,同时将标题栏的鼠标光标设置为拖动(move)形状(在chrome中拖动的时候,光标会变成文字光标,松开鼠标键后恢复),这里需要对标题栏的左上角和右上角设置一下圆角。

/*标题栏区域*/

 1 .popup_title{
 2     height: 48px;
 3     line-height: 48px;                                          /*使垂直居中*/
 4     padding:0px 20px;                                           /*使距离左边有一定距离*/
 5     background: #f5f5f5;                                        /*背景颜色*/
 6     border-bottom: 1px solid #efefef;                           /*底边框*/
 7     border-radius:8px 8px 0 0;                                  /* 左上角和右上角使用半径为5px的圆角,此属性为CSS3标准属性 */
 8     -moz-border-radius: 8px 8px 0 0;                            /* Mozilla浏览器的私有属性 */
 9     -webkit-border-radius:8px 8px 0 0;                          /* Webkit浏览器的私有属性 */ /*窗口圆角*/
10     color: #535353;
11     font-size: 16px;                                            /*字体颜色和字体大小*/
12     cursor: move;                                               /*可移动样式*/
13     -moz-user-select: none;                                     /* Firefox all */
14     -webkit-user-select: none;                                  /* Chrome all / Safari all /opera15+*/
15     -ms-user-select: none;                                      /*IE10*/
16     -khtml-user-select: none;                                   /*早期浏览器*/
17     user-select:none;
18     -o-user-select: none;                                       /* 以上两个属性目前并未支持,写在这里为了减少风险 */
19     }

这里有几个知识点需要理解:

1. css3(border-radius)边框圆角

border-radius 是一种缩写方法。另外其四个值是按照top-lefttop-rightbottom-rightbottom-left的顺序来设置的其主要会有下面几种情形出现:

  1. 只有一个值,那么 top-lefttop-rightbottom-rightbottom-left 四个值相等。
  2. 有两个值,那么 top-left 等于 bottom-right,并且取第一个值;top-right 等于 bottom-left,并且取第二个值
  3. 有三个值,其中第一个值是设置top-left;而第二个值是 top-right bottom-left 并且他们会相等,第三个值是设置 bottom-right
  4. 有四个值,其中第一个值是设置 top-left 而第二个值是 top-right 第三个值 bottom-right 第四个值是设置 bottom-left

支持的浏览器:

如果还是不太明白的话,这里有两篇文章可以参考一下.一篇是阮一峰的CSS3圆角详解,另一篇是w3cplusCSS3的圆角Border-radius,如果你能读完并理解这两篇文章,那么基本上CSS3圆角Border-radius的知识你就掌握的差不多了。

2.  cursor: move

cursor 属性规定所显示的指针(光标)的类型。

属性值为move时,表示此光标所指的对象是可以移动的,通常为一个交叉箭头,如图。

3.user-select用来控制内容的可选择性

auto——默认值,用户可以选中元素中的内容

none——用户不能选择元素中的任何内容

text——用户可以选择元素中的文本

element——文本可选,但仅限元素的边界内(只有IEFF支持)

需要注意的是:user-select并不是一个W3C的CSS标准属性,浏览器支持的不完整,需要对每种浏览器进行调整

user-select说明:

设置或检索是否允许用户选中文本。

(1)IE6-9不支持该属性,但支持使用标签属性 onselectstart="return false;" 来达到 user-select:none 的效果;Safari和Chrome也支持该标签属性;

(2)直到Opera12.5仍然不支持该属性,但和IE6-9一样,也支持使用私有的标签属性 unselectable="on" 来达到 user-select:none 的效果;

(3)unselectable 的另一个值是 off;除Chrome和Safari外,在其它浏览器中,如果将文本设置为 -ms-user-select:none;,则用户将无法在该文本块中开始选择文本。

不过,如果用户在页面的其他区域开始选择文本,则用户仍然可以继续选择将文本设置为 -ms-user-select:none; 的区域文本.

分析以下代码(注意:此代码及此代码的分析结果来自w3help):

 1 <!DOCTYPE html>
 2 <html>
 3 <body>
 4         <div unselectable="on" style="background:#CCC;" >unselectable=on </div>
 5         <br/>
 6         <div style="background:#CCC;-webkit-user-select:none;" >-webkit-user-select:none;</div>
 7         <br/>
 8         <div style="background:#CCC;-moz-user-select:none;" >-moz-user-select:none;</div>
 9         <br/>
10         <div style="background:#CCC;" onselectstart="return false;" >onselectstart="return false;"</div>
11 </body>
12 </html>        

在各浏览器中效果如下:

注1:可以禁止内容选中。

注2:没有禁止内容选中。

可见,禁止内容选中的方法如下:

IE 给标签设置 unselectable= "on" ,设置标签方法 onselectstart="return false;"

Firefox 给标签设置私有样式 -moz-user-select:none 。

Chrome Safari 给标签设置私有样式 -webkit-user-select:none ,设置标签方法 onselectstart="return false;"。

Opera 给标签设置 unselectable= "on"

解决方案

给标签设置样式 -moz-user-select:none ;-webkit-user-select:none 同时标签设置 unselectable= "on" ,保证各浏览器都可以禁止内容选中。

注意:本文为原创,转载请以链接形式标明本文地址 ,谢谢合作。

本文地址:http://www.cnblogs.com/wanghuih/p/5576910.html

时间: 2024-10-08 21:27:17

简单的弹出拖拽窗口(二)的相关文章

简单的弹出拖拽窗口(一)

需求说明: 1,点击页面按钮,弹出窗口: 2,要有半透明背景遮罩: 3,弹出窗口圆角,窗口半透明,但内容不透明:带阴影: 4,窗口可拖动: 5,拖动停止之后,滚动页面时窗口位置不动: 6,可以使用jQuery: 7,有关闭按钮: 进一步功能具体描述: 点按钮,会有一个可以拖拽的浮层出来. 有一个背景遮罩,支持标题栏的拖拽,在标题栏以外,在标题栏区域之外的区域拖拽是没有效果的,拖拽功能限定,他的拖拽功能被限定在可是可视区域内. 拖曳的思路: 获取鼠标的位置,鼠标移动的时候,获取鼠标的位置,获取x轴

position定位解决弹框拖拽出屏幕的情况

position定位有四种情况: 1 static默认情况,没有定位,元素正常出现在文档流中. 2 fixed 绝对定位 元素的位置相对于浏览器窗口是固定位置. 即使窗口是滚动的它也不会移动:定位脱离文档流,不占据位置. 3 relative相对定位,相对其正常位置,还在文档流中,占据位置. 相对定位元素经常被用来作为绝对定位元素的容器块. 4 absolute绝对定位 绝对定位的元素的位置相对于最近的已定位父元素,如果元素没有已定位的父元素,那么它的位置相对于<html> 定位脱离文档流,不

安卓弹出对话框——AlertDialog(二)

在Android中,启动一个对话框有三种方式: 1.定义一个新的activity,并将其主题设置为对话框风格 2.使用AlertDialog类,并且显示它 3.使用 Android的Dialog类的子类,并且显示它 现在学习AlertDialog.Builder创建各种形式的对话框. 首先,看看启动界面如下: 用土司来显示效果,因为多次用到,所以将其抽象为一个方法. [java] view plaincopy protected void showToast(String string) { T

AOPR弹出Order Now窗口怎么办

当我们忘记了我们自己设置的office密码的时候,需要一款office密码破解软件来帮我们破解,Advanced Office Password Recovery就是这样的一款软件,其简称AOPR.试用版破解office密码的过程中有时候会弹出Order Now窗口,窗口中含有多个不同的选项按钮以及大段英文描述.对于这种情况,很多的用户朋友都不知道该怎么办,下面我们就来给大家分享一下AOPR弹出Order Now窗口怎么办? 一.Order Now窗口是什么? “Order Now”翻译成中文就

实现一个简单的弹出层

弹出层的实现方式是让一个块层遮挡住最底下的层,在最顶上显示相应的内容,因为最底下的块级和最上面的块级属于一个页面,他们之间也可以共享一些数据(实现一些特定的操作) 下面是简单的一个实现的过程 首先我们定义一个基本的页面结构 <div id="show"> //最底下的层 <input type="button" value="测试" id="test"/> </div> <div id

JavaScript基础--小案例:在网页指定位置弹出错误信息(十二)

案例分析:点击按钮后,在网页上指定区域,提示错误信息!5秒后,错误信息提示自动消失! 1 <script languag="javascript" type="text/javascript"> 2 var clearId; 3 function test(){ 4 document.getElementById("showMsg").style.cssText="width:200px;height:50px;left:6

自定义HttpModule,用于未登录用户,不弹出Windows认证窗口,而是跳转回SSO站点

2012年的一篇随笔记录,可以学习到如何自定义HttpModule,而具体里面针对需求开发的代码,可能未必能让大伙了解到什么,可快速扫描而过. 1 using System; 2 using System.Web; 3 4 using System.Configuration; 5 using System.Web.Configuration; 6 using Microsoft.SharePoint; 7 using System.Net; 8 using System.Security.Pr

为什么当拖拽窗口时画面停止渲染?

因为当用户拖拽窗口时,窗口会接收到WM_SYSCOMMANDD消息,参数是SC_MOVE. 此时DefWindowProc不会返回,直到鼠标松开. 比较特殊的是WM_ENTERSIZEMOVE和WM_EXITSIZEMOVE你还是可以收到.所以有人的解决方法是在这里加定时器去渲染,但是你要解决的不仅仅是渲染问题,还有逻辑问题.所以,这个方案其实也不完美.个人觉得还是想办法绕开吧....

Tomcat startup.bat启动隐藏弹出的信息窗口

to make tomcat to use javaw.exe instead of java.exeusing some startup parameter or environment varibaleAt the bottom of setclasspath.bat set _RUNJAVA="%JRE_HOME%\bin\java" set _RUNJAVAW="%JRE_HOME%\bin\javaw" These are the settings set