分享 12 个值得收藏的 JavaScript 工具函数

c26aacfd1bab2fd8ce12c5054caeda4b.jpeg

来源 | https://javascript.plainenglish.io/6-useful-javascript-code-snippets-91424efd1c55

今天这篇文章,我跟大家分享12个有用的代码片段,这些代码片段,是我平时工作中,收集整理出来的,我个人觉得比较实用,我把它分享出来,希望可以帮助到你。

1、文件内容上传

4b7736e622eab18df8b394ae1f81342d.gif

var selectContent=document.getElementById("selectContent");
var contentForSelection=document.getElementById("contentForSelection");selectContent.onchange=function(e) {
  if (!window.FileReader) {
   alert("Your browser does not support HTML5 'FileReader' function required to open a file.");
  } else {
   let fileis = this.files[0];
   let fileredr = new FileReader();
   fileredr.onload = function (fle) {
    let filecont = fle.target.result;
    contentForSelection.value=filecont;
   };
   //fileredr.readAsArrayBuffer(fileis);
   fileredr.readAsText(fileis);
  }
};

在上面的例子中,由于我选择导入的文件是文本格式,所以使用 readAsText 方法而不是 readAsArrayBuffer。使用 readAsArrayBuffer 的实例包括读取图像流或读取 ZIP 存档文件。成功导入后,文件内容将自动呈现到元素 id 为“contentForSelection”的文本区域中。

2、保存文件内容

56ad0af32e23a8af250e19c14b792ca3.gif

var saveBtn=document.getElementById("saveBtn");
var contentForSelection=document.getElementById("contentForSelection");
saveBtn.onclick=function() {
 let txtContent=contentForSelection.value;
 if (!window.Blob) {
  alert("Your browser does not support HTML5 'Blob' function required to save a file.");
 } else {
  let textblob = new Blob([txtContent], {
   type: "text/plain"
  });
  let dwnlnk = document.createElement("a");
  dwnlnk.download = "output.txt";
  dwnlnk.innerHTML = "Download File";
  if (window.webkitURL != null) {
    dwnlnk.href = window.webkitURL.createObjectURL(textblob);
  }
  dwnlnk.click();
  }
};

上面的代码片段通常在在线笔记应用程序中实现,以便用户导出他们的输入。或者,在数据/代码格式化程序等 Web 实用程序中,通常还存在 [保存] 功能,以允许用户将后续格式化的文本内容保存到本地存储文件中。

3、复制到剪贴板

复制到剪贴板是基于浏览器设置中的另一个经典功能。通常情况下,如果转换后的输出仅用于 1-Off 任务,则此时不需要将输出保存到文件中,而是使用以下 JS 代码片段更合适:

var copyBtn=document.getElementById("copyBtn");
var contentForSelection=document.getElementById("contentForSelection");
copyBtn.onclick=function(evt) {
 copyBtn.nextElementSibling.innerHTML="";
 copyTransformedOutput("contentForSelection");
 let smallEle=evt.currentTarget.nextElementSibling;
 smallEle.innerHTML="<span style='color:green'> Copied to Clipboard!</span>";
};
function copyTransformedOutput(inputEleId) {
 let copyText = document.getElementById(inputEleId);
 copyText.select();
 copyText.setSelectionRange(0, 99999); /* For mobile devices */
 navigator.clipboard.writeText(copyText.value);
}

请注意,我选择在成功复制代码片段后显示“已复制到剪贴板”消息。

因此,转换后的输出随后可以粘贴到其他地方,无需存储到本地文件中以供使用。

4、查找和替换所有

虽然,在最新的 JavaScript 控制台中,此功能目前是内置的,但由于其独创性和简单性,了解以下 JavaScript 功能,仍然是相关且有用的:

function replaceAll(inputStr,toReplace,replaceWith) {
  return inputStr.split(toReplace).join(replaceWith);
}

例如,如果我想在 textarea 中将“id”替换为“ID”:

6ae3ff1d8c233b18f861bbb2f0dd7b78.gif

其余的代码片段如下:

var replaceBtn=document.getElementById("replaceBtn");
replaceBtn.onclick=function() {
 let toFind=document.getElementById("ToFind").value;
 let replaceWith=document.getElementById("ReplaceWith").value;
contentForSelection.value=replaceAll(contentForSelection.value,toFind,replaceWith);
};

5、生成随机十六进制颜色

我发现这种 JavaScript 方法被低估的一种情况是,当我不得不将多条驾驶路线渲染到同一个 Web 应用程序上时:

41b9f9a85d1185f2d6dae6263201e44c.png

显然区分一个无限的号码。使用不同颜色的重叠驾驶路线,任何查看者都更容易比较和对比显示在地图可视化上的各种路线。因此,动态生成不同的颜色是必要的,可以通过以下方式实现:

function generateRandomHexColor() {
    let colorGenerated="#" + (Math.random() * 0xfffff * 1000000).toString(16).slice(0, 6);
    if(colorGenerated !== "#0000ff" && colorGenerated !== "#ff0000") {
      return colorGenerated;
    }
    colorGenerated="#" + (Math.random() * 0xfffff * 1000000).toString(16).slice(0, 6);
}

6、突出显示 JSON 语法

对于地图服务提供商返回的每条路线,我已经合并了路线的 JSON 数据输出的导出功能。因此,为了区分 JSON 对象中的 String、Float、Integer、Boolean 等对象类型,我选择对其进行颜色编码,如下所示:

6b828104e3b1bf32a6964975c696bd94.png

上述效果可以通过 CSS 和 JavaScript 来实现。

JavaScript 代码:

function syntaxHighlight(json) {
    json = json.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;");
    return json.replace(/("(\\u[a-zA-Z0-9]{4}|\\[^u]|[^\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/g, function (match) {
        var cls = "number";
        if (/^"/.test(match)) {
            if (/:$/.test(match)) {
                cls = "key";
            } else {
                cls = "string";
            }
        } else if (/true|false/.test(match)) {
            cls = "boolean";
        } else if (/null/.test(match)) {
            cls = "null";
        }
        return "<span class='" + cls + "'>" + match + "</span>";
    });
}

CSS 代码:

.string { 
  color: green; 
}
.number { 
  color: darkorange; 
}
.boolean { 
  color: blue; 
}
.null { 
  color: magenta; 
}
.key { 
  color: red; 
}

7、通知未保存的更改

c560985bda28260ed236767740021b00.gif

window.addEventListener('beforeunload', (event) => {
  event.preventDefault();
  event.returnValue = '';
});

上面的代码片段对于用户在输入字段中输入了未保存的数据,并且如果页面被卸载将丢失的情况特别有用。在上图中,用户上传了多个图像文件后,浏览器会提示用户是否保存了图像输出,以防止数据丢失。

8、异步上传多个文件

function readFileAsB64(file) {
    return new Promise((resolve,reject) => {
        let fileredr = new FileReader();
        fileredr.onload = () => resolve([fileredr.result, file.name]);
        fileredr.onerror = (err) => reject(err);
        fileredr.readAsDataURL(file);
    });
}
var uploadFile=document.getElementById('uploadFile'); // input[type='file']
uploadFile.addEventListener('change', (ev) => {  
    if (!window.FileReader) {
        alert('Your browser does not support HTML5 "FileReader" function required to open a file.');
    } else {
      let filesArr=ev.target.files;
      let fileReaders=[];
      for(let f in filesArr) {
        if(!isNaN(f)) fileReaders.push(readFileAsB64(filesArr[f]))
      }
      Promise.all(fileReaders).then((outputArrs) => {
          for(let o in outputArrs) {
            if(!isNaN(o)) {
              let fileArr=outputArrs[o]; // [fileredr.result, file.name]
              /* TO DO LOGIC HERE */
              let image = new Image();
              image.src = fileArr[0];
              image.title = fileArr[1];
              image.height = 100;
              document.body.appendChild(image);
            }
          }
      });
    }
});

上面的代码片段确保在浏览器继续执行注释后的代码逻辑之前,所有上传的图像文件都已编码为 Base64 字符串:(fileredr.readAsDataURL(file);)

/* TO DO LOGIC HERE */

3d66450dedf9cdfb6ddfca078d05e2ce.gif

9、 insertAdjacentHTML——beforebegin | 开始后 | 之前 | 尾端

参考第 7 条中的屏幕截图,可以通过 insertAdjacentHTML(<position>,<HTML String>) 将 HTML 附加到元素:

<Element>.insertAdjacentHTML
('beforeend'|'afterbegin'|'beforeend'|'afterend', <HTML String>);

下面是每个选项所指的相对于 <Element>(即 <p></p>)的位置的说明:

<!-- beforebegin -->
<p>
  <!-- afterbegin -->
  foo
  <!-- beforeend -->
</p>
<!-- afterend -->

由于在第 7 点中,目标是附加额外的表行 (<tr></tr>),因此使用了 beforeend 的位置。

10、检查JSON字符串是否有效

由于我在创建的大多数离线浏览器实用程序都需要用户上传数据文件,其中一些需要 JSON 格式,这是对 JSON 文件进行数据格式验证检查的简单直接的方法 是:

function isValidJSON(str) {
  try {
    JSON.parse(str);
    return true;
  } catch (e) {
    return false;
  }
}
// returns a Boolean

11、将原始 HTML 字符串编码为 Unicode 实体

function encodeHTMLChars(rawStr) {
  return rawStr.replace(/[\u00A0-\u9999<>\&]/g, ((i) => 
  `&#${i.charCodeAt(0)};`));
  }

要将文本 <img> 显示到 HTML 页面上,必须对字符串进行如下编码:

var inputHTMLStr='<img>';
var encodedHTMLStr=encodeHTMLChars(inputHTMLStr);
console.log(encodedHTMLStr); 
// Output: &#60;img&#62;

当需要在网页上显示 HTML 代码片段时,这通常会派上用场,因为其原始形式(即“<img>”)被浏览器自动解释为 HTML DOM 元素,而不是用于显示的原始文本。

12、 将 XML 转换为 JSON

使用率最低的 2 个 JavaScript API 包括:DOMParser() 和 DOMParser.parseFromString()

尽管 xml-js 和 xml2js 等 npm 包很容易获得,但此逻辑可以通过纯 JavaScript 实现,如下所示:

function convertXMLtoJSON(xmlObj) { // adapted from https://davidwalsh.name/convert-xml-json
    var obj = {};
    if (xmlObj.nodeType == 1) {
        if (xmlObj.attributes.length > 0) {
            obj['@attributes'] = {};
            for (var j = 0; j < xmlObj.attributes.length; j++) {
                var attribute = xmlObj.attributes.item(j);
                obj['@attributes'][attribute.nodeName] = attribute.nodeValue;
            }
        }
    } else if (xmlObj.nodeType == 3) {
        obj = xmlObj.nodeValue;
    }
    // Iterate through all child nodes
    // Use recursive to assign nested nodes
    if (xmlObj.hasChildNodes()) {
        for(var i = 0; i < xmlObj.childNodes.length; i++) {
            var item = xmlObj.childNodes.item(i);
            var nodeName = item.nodeName;
            if (typeof(obj[nodeName])==='undefined') {
                obj[nodeName] = convertXMLtoJSON(item);
            } else {
                if (typeof(obj[nodeName].push)==='undefined') {
                    var old = obj[nodeName];
                    obj[nodeName] = [];
                    obj[nodeName].push(old);
                }
                obj[nodeName].push(convertXMLtoJSON(item));
            }
        }
    }
    return obj;
}


/* USAGE: Sample xmlText */
var xmlText = '<bookstore><book>' +
'<title>Everyday Italian</title>' +
'<author>Giada De Laurentiis</author>' +
'<year>2005</year>' +
'</book></bookstore>';


var xmlParser=new DOMParser();
var xmlObj=xmlParser.parseFromString(xmlText, 'text/xml');


var jsonObj=convertXMLtoJSON(xmlObj);
console.log(jsonObj);
// Output: {"bookstore":{"book":{"title":{"#text":"Everyday Italian"},"author":{"#text":"Giada De Laurentiis"},"year":{"#text":"2005"}}}}

免责声明:上述代码逻辑最初由 David Walsh 在 Convert XML to JSON 中实现。

总结

以上就是我今天跟你分享的12个我觉得有用且值得分享的 JavaScript 代码片段,希望这些代码片段能够帮助到你。如果你觉得有用的话,请记得点赞我,关注我,并将它分享给你的朋友,也许能够帮助到他。

最后,感谢你的阅读,祝编程愉快!

学习更多技能

请点击下方公众号

0ea4e2800229a9abba1a9a8f20d18733.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值