亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于JavaScript如何實現新手引導效果

發布時間:2023-03-07 11:55:57 來源:億速云 閱讀:219 作者:iii 欄目:開發技術

這篇文章主要介紹了基于JavaScript如何實現新手引導效果的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇基于JavaScript如何實現新手引導效果文章都會有所收獲,下面我們一起來看看吧。

    一、實現效果

    基于JavaScript如何實現新手引導效果

    二、實現

    實現其實很簡單,mask蒙版就是平鋪一個整屏的 div,設置背景顏色為透明 transparent ,然后,再設置 outline 為半透明及足夠寬就可以了,再用同樣的方式創建一個 箭頭警告 標簽。

    1、用法

    let maskIntroduceManage = new MaskIntroduceManage([
        new MaskIntroduceItem('one','人生若只如初見'),
        new MaskIntroduceItem('two','何事秋風悲畫扇'),
        new MaskIntroduceItem('five','等閑卻變故人心'),
        new MaskIntroduceItem('six','驪山語罷清宵半'),
        new MaskIntroduceItem('four','卻道故人心易變'),
        new MaskIntroduceItem('finally','謝謝大家支持!')
    ])
    maskIntroduceManage.benginIntroduce()

    2、HTML

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    </head>
    <style type="text/css">
    *{
        padding: 0;
        margin: 0;
    }
    .content {
        padding: 0;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        width: 100%;
    }
    span {
        width: 60px;
        height: 60px;
        line-height: 60px;
        margin-left: 40px;
        margin-top: 140px;
        margin-bottom: 0px;
        text-align: center;
        display: block;
        background-color: antiquewhite;
    }
    
    .finally {
        width: 100px;
        height: 100px;
        background-color: cornsilk;
        border-radius: 50%;
        line-height: 100px;
        text-align: center;
        margin-top: 30px;
        margin-left: auto;
        margin-right: auto;
    }
    span:nth-of-type(1){
        margin-top: 30px;
    }
    span:nth-of-type(2){
        margin-top: 70px;
    }
    span:nth-of-type(3){
        margin-top: 160px;
    }
    span:nth-of-type(4){
        margin-top: 160px;
    }
    span:nth-of-type(5){
        margin-top: 70px;
    }
    span:nth-of-type(6){
        margin-top: 30px;
    }
    </style>
    <body>
    <div class="content">
        <span id="one">納</span>
        <span id="two">蘭</span>
        <span id="three">容</span>
        <span id="four">若</span>
        <span id="five">作</span>
        <span id="six">詞</span>
    </div>
    <div class="finally" id="finally">
        謝謝
    </div>
    </body>
    <script src="./maskIntroduce.js"></script>
    <script>
    let maskIntroduceManage = new MaskIntroduceManage([
        new MaskIntroduceItem('one','人生若只如初見'),
        new MaskIntroduceItem('two','何事秋風悲畫扇'),
        new MaskIntroduceItem('five','等閑卻變故人心'),
        new MaskIntroduceItem('six','驪山語罷清宵半'),
        new MaskIntroduceItem('four','卻道故人心易變'),
        new MaskIntroduceItem('finally','謝謝大家支持!')
    ])
    maskIntroduceManage.benginIntroduce()
    </script>
    </html>

    3、JS

    // 單元信息model
    class MaskIntroduceItem {
        // 需要引導的dom的ID
        id
        // 需要引導的dom功能描述
        warming
        constructor(id,warming){
            this.id = id
            this.warming = warming
        }
    }
    
    // 遮罩操作類
    class MaskIntroduceManage {
        // 消息展示類集合
        maskIntroduceItems
        // 遮罩層
        el
        // 遮罩層提示框
        warmingEl
        // 指引肩頭
        guidanceEl
        // 展示的第幾個
        currentShowIndex = 0
        // 記錄window事件
        windowEvent = null
        
        constructor(maskIntroduceItems){
            this.maskIntroduceItems = maskIntroduceItems
        }
        
        // 添加消息展示類
        addIntroduceItem(introduceItem){
            this.maskIntroduceItems.push(introduceItem)
        }
        
        // body增加遮罩
        addMaskToBody(){
            //添加遮罩框
            this.el = document.createElement('div')
            this.el.style.cssText = 'position: fixed;background: transparent;outline:rgba(0, 0, 0, 0.5) 3500px solid;'
            let body = document.getElementsByTagName('body')[0]
            body.appendChild(this.el)
            //添加提示框
            this.warmingEl = document.createElement('div')
            this.warmingEl.style.cssText = 'position:fixed;width:100px;background:white;border-radius: 10px;padding: 30px;font-size: 14px;'
            body.appendChild(this.warmingEl)
            //添加指引箭頭
            this.guidanceEl = document.createElement('div')
            this.guidanceEl.style.cssText = 'position:fixed;width: 14px; height: 13px; background-color: white;clip-path: polygon(50% 0,100% 100%,0 100%);'
            body.appendChild(this.guidanceEl)
            //設置body禁止滾動
            body.style.overflow = 'hidden'
            //保留window事件
            if(window.onclick){
                this.windowEvent = window.onclick
            }
            window.onclick = ()=>{
                this.nextIntroduce()
            }
        }
    
        // 開始引導
        benginIntroduce(){
            this.addMaskToBody()
            this.nextIntroduce()
        }
        
        // 下一步
        nextIntroduce(){
            let maskIntroduceItem = this.maskIntroduceItems.length > 0 ? this.maskIntroduceItems[this.currentShowIndex] : null
            if(!maskIntroduceItem){
                return
            }
            let needIntroduceEl = document.getElementById(maskIntroduceItem.id)
            //遮罩層的鏤空位置
            this.el.style.width = needIntroduceEl.offsetWidth + 'px'
            this.el.style.height = needIntroduceEl.offsetHeight + 'px'
            this.el.style.top = this.getElementPosition(needIntroduceEl).top + 'px'
            this.el.style.left = this.getElementPosition(needIntroduceEl).left + 'px'
            //設置對應倒角,但是由于背景顏色是透明的,所以,沒有效果(????????????)
            //this.el.style.borderRadius = window.getComputedStyle(needIntroduceEl,null)['border-radius']
            this.currentShowIndex ++
            //指引箭頭位置
            let guidanceElLeft = this.getElementPosition(needIntroduceEl).left + needIntroduceEl.offsetWidth / 2.0
            this.guidanceEl.style.top = this.getElementPosition(needIntroduceEl).top + needIntroduceEl.offsetHeight + 20 + 'px'
            this.guidanceEl.style.left = guidanceElLeft + 'px'
            //提示框的位置
            this.warmingEl.style.top = this.getElementPosition(this.guidanceEl).top + this.guidanceEl.offsetHeight - 4 + 'px'
            let warmingElLeft = this.getElementPosition(needIntroduceEl).left - ((this.warmingEl.offsetWidth - needIntroduceEl.offsetWidth) / 2.0)
            if(warmingElLeft < 0){
                warmingElLeft = this.getElementPosition(needIntroduceEl).left + 10
            }
            if(warmingElLeft + this.warmingEl.offsetWidth > document.getElementsByTagName('body')[0].offsetWidth){
                warmingElLeft = warmingElLeft - 10 - (this.warmingEl.offsetWidth - needIntroduceEl.offsetWidth) / 2.0
            }
            this.warmingEl.style.left = warmingElLeft + 'px'
            this.warmingEl.innerHTML = maskIntroduceItem.warming
            //最后一個展示完恢復window點擊事件
            if(this.currentShowIndex >= this.maskIntroduceItems.length){
                setTimeout(() => {
                    //移除當前遮罩
                    this.el.remove()
                    //移除當前提示框
                    this.warmingEl.remove()
                    //移除箭頭
                    this.guidanceEl.remove()
                    //設置body可以滾動
                    document.getElementsByTagName('body')[0].style.overflow = 'auto'
                    //恢復window事件
                    if(this.windowEvent){
                        window.onclick = this.windowEvent
                    }
                }, 2000);
            }
        }
    
        // 獲取元素在屏幕的位置
        getElementPosition(element){
            var top = element.offsetTop
            var left = element.offsetLeft
            var currentParent = element.offsetParent;
            while (currentParent !== null) {
                top += currentParent.offsetTop
                left += currentParent.offsetLeft
                currentParent = currentParent.offsetParent
            }
            return {top,left}
        }
    }

    關于“基于JavaScript如何實現新手引導效果”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“基于JavaScript如何實現新手引導效果”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    思茅市| 龙岩市| 龙山县| 九寨沟县| 札达县| 砀山县| 延川县| 马公市| 文成县| 武夷山市| 十堰市| 武汉市| 中江县| 廊坊市| 伽师县| 中卫市| 西贡区| 宜春市| 甘德县| 新巴尔虎右旗| 霸州市| 大余县| 余庆县| 古田县| 上林县| 繁峙县| 桐庐县| 石门县| 平南县| 红原县| 蒲江县| 昆明市| 建水县| 宜宾县| 内江市| 竹溪县| 霍山县| 景东| 赫章县| 青阳县| 绿春县|