关闭

js如何实现新手引导效果?

时间: 2018-04-25阅读: 4637标签: 效果

js最近有个小伙伴问到了怎么实现新手引导的效果,然后便去网上找了下实现方案。可以通过css的border来实现。效果图如下:


具体代码如下:  

<!DOCTYPE html PUBLIC "-//W3C//DTD Xhtml 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.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>css实现用户引导</title>
    <style type="text/css">
        html, body {
            width: 100%;
            height: 100%;
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        #first-step {
            height: 100px;
            width: 300px;
            border: 1px solid black;
            border-radius: 4px;
            line-height: 100px;
            text-align: center;
            position: absolute;
            top: 50px;
            left: 200px;
        }

        #second-step {
            height: 100px;
            width: 300px;
            border: 1px solid black;
            border-radius: 4px;
            line-height: 100px;
            text-align: center;
            position: absolute;
            top: 50px;
            left: 800px;
        }

        #third-step {
            height: 100px;
            width: 300px;
            border: 1px solid black;
            border-radius: 4px;
            line-height: 100px;
            text-align: center;
            position: absolute;
            top: 500px;
            left: 200px;
        }

        .mask-tip {
            min-width: 175px;
            text-align: center;
            border: 1px solid rgb(0, 94, 166);
            border-radius: 4px;
            padding: 5px 10px;
            position: absolute;
            top: 120px;
            left: 65px;
            background: white;
        }

        .mask-tip:before {
            content: "";
            width: 10px;
            height: 10px;
            border: 1px solid rgb(0, 94, 166);
            background: white;
            position: absolute;
            transform: rotate(45deg);
            top: -6px;
            left: 85px;
            border-right-width: 0;
            border-bottom-width: 0;
        }

        .mask-tip-desc {
            display: block;
            margin-bottom: 10px;            
        }

        .mask-tip-btn {
            border-radius: 4px;
            padding: 6px;
            border: none;
            background-color: rgb(0, 94, 166);
            cursor: pointer;
            color: white;
        }
    </style>
</head>
<body>
    <div id="first-step">第一步</div>

    <div id="second-step">第二步</div>

    <div id="third-step">第三步</div>

    <div id="mask">
        <div class="mask-tip">
            <span id="mask-desc" class="mask-tip-desc"></span>
            <button id="mask-next" class="mask-tip-btn">下一步</button>
        </div>
    </div>
</body>
<script type="text/JavaScript">
    function getElementById(id) {
        return document.getElementById(id);
    };

    function mask(params) {
        var mask = getElementById('mask');

        if (params.length === 0) {
            mask.style.display = 'none';
            return;
        }

        var {id, desc} = params[0];

        /****************   获取要cover的元素基本信息   ****************/
        var ele = getElementById(id);
        var offsetWidth = ele.offsetWidth;
        var offsetHeight = ele.offsetHeight;
        var offsetLeft = ele.offsetLeft;
        var offsetTop = ele.offsetTop;

        console.log(offsetWidth, offsetHeight, offsetLeft, offsetTop);

        /****************   获取屏幕大小,包含滚动区域   ****************/
        var scrollWidth = document.body.scrollWidth;
        var scrollHeight = document.body.scrollHeight;

        console.log(scrollWidth, scrollHeight);

        /****************   为Mask设置css   ****************/        
        mask.style.width = scrollWidth + 'px';
        mask.style.height = scrollHeight + 'px';
        mask.style.borderColor = "rgba(0, 0, 0, 0.75)";
        mask.style.borderStyle = 'solid';
        mask.style.borderLeftWidth = offsetLeft - 5 + 'px';
        mask.style.borderRightWidth = (scrollWidth - offsetWidth - offsetLeft - 5) + 'px';
        mask.style.borderTopWidth = offsetTop - 5 + 'px';
        mask.style.borderBottomWidth = (scrollHeight - offsetHeight - offsetTop - 5) + 'px';
        mask.style.position = 'absolute';
        mask.style.left = 0;
        mask.style.top = 0;

        /****************   为Mask设置desc   ****************/        
        var maskDesc = getElementById('mask-desc');
        maskDesc.innerHTML = desc;

        /****************   绑定next事件   ****************/
        var nextBtn = getElementById('mask-next');
        (function(mask) {
            nextBtn.onclick = function() {
                params.shift();
                mask(params);
            };    
        })(arguments.callee);
    };

    mask([
        {
            id: 'first-step',
            desc: '我是第一步的说明'
        },
        {
            id: 'second-step',
            desc: '我是第二步的说明'
        },
        {
            id: 'third-step',
            desc: '我是第三步的说明'
        }
    ]);
</script>
</html>


来源:https://blog.csdn.net/oliver940910/article/details/75451847

站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/710

关闭

CSS 搞怪的 text-decoration

今天在改一个项目的时候却遇到了一个莫名其妙的属性:text-decoration,这个属性,其实就只是用来把一段文字加上上横线、删除线或底线的属性罢了,通常会用在移除超链接的底线、或一些特殊强调的效果里头

css滚动视差之水波纹效果

核心属性: background-attachment;这个属性就牛逼了, 它可以定义背景图片是相对视口固定,还是随着视口滚动, 加上这个属性网页瞬间就从屌丝变成高大上。

css实现开关效果

我们使用<input type=\\\\\\\"checkbox\\\\\\\">标签来实现这个效果。checkbox的选中、未选中的特性,刚好对应开关的打开、关闭;on:打开 off:关闭;开始画出off、on状态的草图

用CSS新属性实现特殊的图片显示效果

使用一个或多个图像相关的CSS属性(background-blend-mode, mix-blend-mode, or filter)可以实现许多特殊的图片显示效果。本文转载自Bennett Feely的个人网站,文中共列举了20种图片显示效果。

css文字选中效果

文字选中效果,这个可能很少有人注意过。在默认状态先一般选中的文本颜色是白字蓝底的,不过可以通过CSS进行设置。::selection定义元素上的伪选择器,以便在选定元素时设置其中文本的样式。

原生JS快速实现拖放(drag and drop)效果

拖放是很常见的一种交互效果,很多时候我们都会借助于第三方的控件来实现,其实用原生js实现起来也非常的方便。接下来我们就用原生js和css快速实现这样的拖放效果:

使用原生JS实现图片放大镜效果

前提先了解数学算法:求遮罩层mask宽度,大图、大图显示区、小图、遮罩层;小图是大图等比缩放的,遮罩层是大图显示区缩放的,小图/大图 = 遮罩层/大图显示区,遮罩层 = 大图显示区*(小图/大图);

CSS遮罩效果(模糊效果,阴影效果,毛玻璃效果)

一般遮罩加上透明度opacity就是阴影效果。阴影效果和一般遮罩一样,唯一不同的是设置.mask遮罩的背景色用rgba()表示,当然hsla()也是可以的。模糊效果(毛玻璃效果) 通过 filter来实现

css左边竖条的实现方法

问题描述:在只使用一个标签的情况下实现左边竖线。使用border;使用伪元素来实现;内/外阴影;drop-shadow;渐变 linearGradient

纯代码为网站站点添加雪花飘落效果

网站站点添加雪花飘落效果,本段js代码依赖 JQurey,如果没效果,请确认网页是否已载入 JQurey 。代码如下:

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!