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

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

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

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

vue2实现带地区编号和名称的省市县三级联动效果

我们知道省市区县都有名称和对应的数字唯一编号,使用编号可以更方便查询以及程序处理,我们今天来了解一下使用vue2来实现常见的省市区下拉联动选择效果。

炫酷的播放粒子效果,你也可以学会!使用Web动画API制作

当谈到运动和动画时,可能没有什么比粒子更让我喜欢了,这就是为什么每次我探索新技术时,我总是以尽可能多的创建粒子来演示。在本文中,单击按钮时,我们将使用Web Animations API创建烟花效果

Vue实现吸顶效果

因为项目需求,最近开始转到微信公众号开发,接触到了Vue框架,这个效果的实现虽说是基于Vue框架下实现的,但是同样也可以借鉴到其他地方,原理都是一样的。因为在css中我们可以设置一个元素的position: fixed;

html刮刮卡效果实现

公司国庆搞了个集卡、抽奖小活动。抽奖需要刮刮卡的效果,感觉 css 是实现不了。看我使用 canvas 如何实现刮刮卡效果。clearRect 这是我第一个找到的 API,作用是清除一个矩形区域内的内容

CSS实现文字下面波浪线动画效果

就是使用径向渐变绘制我们的波浪线效果,一个波浪线循环段是有一个朝上的半个圆弧和一个朝下的半个圆弧组合而成的。所以,我们只要使用径向渐变绘制圆弧

使用CSS实现逼真的水波纹点击效果

虽然webkit具有遮罩的能力(webkit mask),不过webkit虽然强大,但在跨浏览器上总是它的罩门,况且在性能上也是往往会造成困扰(这也是为什么chrome要这么吃资源了),因此撇开webkit不谈,我们该用什么方法,才可以做出水波纹的效果呢?

JavaScript写一个简单的Ps滤镜效果

CSS3多了一个filter的属性,非常强大(兼容性一般)!我们只要根据输入的值/滑块滑动的值来动态更改css中filter属性的值即可,写一个过滤属性滑块和输入框,互相绑定值,如果用vue就简单了

Vue实现网页放大镜效果

组件使用less,请确保已安装loader,本组件为放大镜组件,传参列表为:width: 必传,设置放大镜的宽高(正方形),放大区域等同,放大倍数为2倍,picList:必传,传入图片列表

css3的transform:tanslateZ没有效果

关于css动画tansform:translateZ(100PX)没有效果的记录,之前学习cs3动画就学的迷迷糊糊的,这次项目中刚好用到了cs3动画,遇到了一个问题,记录下来,方便后期查阅

css如何实现首字下沉效果?

在CSS中可以使用伪元素::first-letter来选中一段文本的首字,然后使用font-size属性设置首字大小,在通过float属性来将实现下沉效果。:first-letter 伪元素向文本的第一个字母添加特殊样式。

点击更多...

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