子比主题美化 - 文章前台编辑,离开页面会提示保存功能

文章最后更新时间:2024-09-25 09:47:18

当我们在前台发帖或发文章页面编辑一大堆内容,如果忘记手动保存,直接访问其他页面后,所有内容就丢失了。
平时只自己发文章可能觉得无所谓,如果网站有用户发帖与文章,此功能还是很友好的。

tips:无法实现自动保存,因为这样保存的请求可能被攻击者调用,如果将请求前加一个人机验证,那也是多次一举,不如提醒让用户自己手动保存。

原作者:瑾年

效果如下图:

图片[1]-子比主题美化 - 文章前台编辑,离开页面会提示保存功能-青争开放社区

代码部署

将以下代码保存到主题设置,自定义代码,自定义底部代码,这样即使更新主题也能用:

<!-- 提示编辑保存js开始-->
<script type="text/javascript">
let whiteList = ['/newposts','/posts-edit/']
let flag = whiteList.includes(window.location.pathname)  ? true : false
let formListenerAdded = false;
function listeningForm() {
    var hasChanges = false;
    var oldXHR = window.XMLHttpRequest;
    setTimeout(function() {
    var iframe = document.getElementById('post_content_ifr');
    if (iframe) {
        var iframeDoc = iframe.contentDocument || iframe.contentWindow.document;
        // 创建一个observer实例
        var observer = new MutationObserver(function(mutations) {
            mutations.forEach(function(mutation) {
                hasChanges = true
            
            });
        });
        
        // 配置observer实例连接到具体的DOM元素和配置观察选项
        var config = { attributes: true, childList: true, characterData: true, subtree: true };
        observer.observe(iframeDoc.documentElement, config);
        
        // 当不再需要观察时,可以断开observer
        
        }
    }, 1000);  // 延迟1000毫秒后执行
    // 监听所有表单输入的变化
     Array.from(document.querySelectorAll('input, textarea, select')).forEach(function(element) {
        element.addEventListener('input', function() {
            hasChanges = true;
      
        });
    });

    // 如果使用WordPress的TinyMCE编辑器,也要监听它的变化
    if (typeof tinyMCE !== 'undefined') {
        tinyMCE.editors.forEach(function(editor) {
            editor.on('change', function() {
                hasChanges = true;
            });
        });
    }
    
    function newXHR() {
        var realXHR = new oldXHR();
        realXHR.addEventListener('readystatechange', function() {
            if (realXHR.readyState === 4) { // 请求完成 ' https://www.你的域名.cn/wp-admin/admin-ajax.php'
                if (realXHR.responseURL =='https://www.你的域名.cn/wp-admin/admin-ajax.php') {
                    hasChanges= false
                   
                }
            }
        }, false);

        return realXHR;
    }
    window.XMLHttpRequest = newXHR;
    // 在尝试离开页面时弹出警告
    window.addEventListener('beforeunload', function(event) {
        if (hasChanges) {
            var message = '您有未保存的更改。如果离开此页面,您可能会丢失这些更改。';
            event.returnValue = message;
            return message
        }
        
    });
}
document.addEventListener('DOMContentLoaded', function() {
    if (!formListenerAdded && flag) {
        listeningForm();
        formListenerAdded = true;
    }
});
</script>
<!-- 提示编辑保存js结束-->
本社区资源仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
© 版权声明
THE END
小青建议:机会是留给有准备的人
分享
评论 抢沙发

请登录后发表评论

    暂无评论内容