引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (2024)

在当今数字时代,大型模型的智能化已成为科学研究和工程应用的焦点之一。然而,要使这些大型模型真正聪明化并实现革新,需要深入挖掘其潜力,并结合创新的工具与技术进行实践探索。在这个引人注目的领域中,JS-Tool-Big-Box(JavaScript 工具大盒)正以其独特的特性和功能脱颖而出。

JS-Tool-Big-Box 是一个强大的工具集,提供了丰富的功能和灵活性,为大型模型的智能化革新提供了坚实的支持。它不仅为研究人员和工程师们提供了方便易用的开发环境,还为他们提供了丰富的算法库和工具箱,从而加速了模型的实验和部署过程。

本文将深入探讨如何通过 JS-Tool-Big-Box 这一强大工具的实践应用,引领大型模型的智能化革新。我们将剖析其核心功能和优势,并结合实际案例,展示其在模型训练、优化和部署过程中的作用。通过深入挖掘 JS-Tool-Big-Box 的潜能,我们有信心在大型模型智能化的道路上取得新的突破,为未来的智能科技发展开辟更加广阔的前景。

在这个充满挑战和机遇的时代,让我们携手探索,引领大型模型智能化革新的未来!

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (1)

目录

引言

1 安装js-tool-big-box工具包

1.1 安装

1.2 截至目前的方法集合

2 时间日期类

2.1 更灵活的年月日时分秒

2.2日期时间转换

2.3 个性的时间组合

2.4 某个时间距离现在

2.5 平年还是闰年

2.6 指定月份的天数

2.7 属相

2.8 获取指定年份的法定节假日

3 页面存储类

3.1 获取浏览器url参数值

3.2 设置cookie

3.3 获取cookie

3.4 删除cookie

3.5 设置localStorage

3.6 获取localStorage的值

4 事件相关

4.1 防抖

4.2 节流

5 Number相关方法学习

5.1 千分号分割

5.2 判断是否大于0

5.3 判断是否大于0的整数

5.4 生成指定范围内的随机数

5.5 生成指定位数的随机数

5.6 数字转小写中文

5.7 数字转大写中文

6 字符串相关方法学习

6.1 字符串反转

6.2 横岗转小驼峰

6.3 横岗转大驼峰

6.4 版本号比较

6.5 获取字符串字节长度

6.6 生成UUID

6.7 通过身份证号获取生日、性别和年龄

6.8 字符串中间加星号遮盖

7 正则验证相关方法学习

7.1 邮箱验证

7.2 手机号验证

7.3 url格式验证

7.4 身份证号码格式验证

7.5 IP地址格式验证

7.6 邮政编码验证

7.7 是否Unicode字符

8 发送请求相关

8.1 发送JSONP跨域请求

9 data数据相关方法学习

9.1 获取幸运者

9.2 复制文字到剪贴板

9.3 数组去重

10 浏览器相关

10.1 判断是否手机端浏览器

10.2 检测某个元素是否处于可视范围内

最后

引言

在前端开发中,JavaScript是必不可少的一部分,而掌握各种常用的公共方法更是提升开发效率和代码质量的关键。无论你是初学者还是资深开发者,了解并熟练运用这些方法都能让你的代码更加简洁、高效。本篇博客将为你详细汇总并解析最全的JavaScript公共方法,涵盖数组、对象、字符串、日期等各个方面的常用技巧。希望通过这篇文章,能为你的前端开发之路提供有力的帮助,成为你开发过程中不可或缺的参考指南。

下面开始啦,建议收藏起来,前端开发项目必备。

1 安装js-tool-big-box工具包

1.1 安装

我已经将所有公共方法,按模块的形式,集成到了js-tool-big-box工具包中,大家不比担心安装后会使项目体积变大,不会的。

执行安装命令:

npm ijs-tool-big-box

npm包地址:js-tool-big-box - npm (npmjs.com)包中提供了工具的学习文档地址以及作者

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (2)

1.2 截至目前的方法集合

那么js-tool-big-box这个方法库现在都有哪些公共方法可以供大家使用了呢,我们看一下下面的图就知道啦

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (3)

2 时间日期类

想要使用时间日期类的公共方法,需要先在项目中导入timeBox 对象,所有的时间日期类方法都在这个对象下面,引入代码如下:

import { timeBox } from 'js-tool-big-box';

2.1 更灵活的年月日时分秒

 const year = timeBox.getMyYear(null, '年'); console.log(year); // 2024年 const yearALB = timeBox.getMyYear(null, 'سنة'); console.log(yearALB); // 2024سنة const month = timeBox.getMyMonth(null, '月'); console.log(month); // 05月 const date = timeBox.getMyDate(null); console.log(date); // 23 const hour = timeBox.getMyHour(null, 'hour'); console.log(hour); // 20hour const minutes = timeBox.getMyMinutes(null, 'min'); console.log(minutes); // 10min const seconds = timeBox.getMySeconds(null, '秒'); console.log(seconds); // 10秒

2.2日期时间转换

 const dateTime1 = timeBox.getFullDateTime(null, 'YYYY-MM-DD', '/'); console.log(dateTime1); // 2024/05/22 const dateTime2 = timeBox.getFullDateTime(null, 'YYYY-MM-DD hh:mm', '~'); console.log(dateTime2); // 2024`05`22 20:11 const dateTime3 = timeBox.getFullDateTime(null, 'YYYY-MM-DD hh:mm:ss'); console.log(dateTime3); // 2024-05-22 20:11:22

2.3 个性的时间组合

const hourShow= timeBox.getMyDate(null, '点');const minShow= timeBox.getMyMinutes(null, '分');const timeShow = `${hourShow} ${minShow}`; // 8点 22分

2.4 某个时间距离现在

const unitObj = { beforeUnit: 'before', afterUnit: 'after', yearUnit: 'year', monthUnit: 'month', dateUnit: ' days ', hourUnit: 'hour', minutesUnit: 'min', secondUnit: 'sec' } const showData = timeBox.getDistanceNow('1908-12-02 06:00:00', unitObj); // 溥仪登基啦 console.log('溥仪登基详细时间===', showData); const showData1 = timeBox.getDistanceNow('2030-04-19 20:15:59'); // 移民火星啦 console.log('人类移民火星详细时间===', showData1);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (4)

注意:这个方法返回的是详细的时间对象,需要甄别使用哪个具体的详细信息。

2.5 平年还是闰年

 const leapYear = timeBox.getLeapYear('2024-12'); console.log('=-=2024年是', leapYear ? '闰年': '平年'); // 闰年 const leapYear1 = timeBox.getLeapYear('2019'); console.log('=-=2019年是', leapYear1 ? '闰年': '平年'); // 平年 const leapYear2 = timeBox.getLeapYear(null); console.log('=-=今年是', leapYear2 ? '闰年': '平年'); // 闰年

2.6 指定月份的天数

 const days = timeBox.getDaysInMonth('2023', 11); console.log('2023年12月的天数===', days); // 31 const days1 = timeBox.getDaysInMonth(null, 1); console.log('今年2月的天数===', days1); // 29

2.7 属相

 const bornAnimal = timeBox.getAnimalOfBorn('2025'); console.log('2025年出生的人属相是:==-==', bornAnimal); // snake const bornAnima2 = timeBox.getAnimalOfBorn('1990-10-25'); console.log('1990年出生的人属相是:==-==', bornAnima2); // house

2.8 获取指定年份的法定节假日

const holiday2024 = timeBox.getHoliday('2024');console.log('----', holiday2024);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (5)

注意:这个方法只能获取2024年以后的法定节假日显示

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (6)

3 页面存储类

页面存储包含获取浏览器url的参数,cookie设置、获取、删除等,localStorage的设置,获取等。想使用存储类的公共方法,需要先在项目中导入storeBox 对象:

import { storeBox } from 'js-tool-big-box';

3.1 获取浏览器url参数值

以 http://127.0.0.1:8080/#/404?type=text&go2=232323&q=my2521 为例

const param = storeBox.getUrlParam('q');console.log('获取到q的参数为:::', param); // my2521

3.2 设置cookie

storeBox.setCookie('school', '我的中学', 1000*10);storeBox.setCookie('name', 'zhangsan');

3.3 获取cookie

const myCookie1 = storeBox.getCookie('school');console.log('我设置过的school是::', myCookie1); // 我的中学

3.4 删除cookie

storeBox.deleteCookie('name');const myNmaeCookie = storeBox.getCookie('name');console.log('我已把name这个cookie删了::', myNmaeCookie);

3.5 设置localStorage

storeBox.setLocalstorage('today', '星期一', 1000*6);

3.6 获取localStorage的值

const today = storeBox.getLocalstorage('today');console.log('6秒后获取的值===', today);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (7)

4 事件相关

目前事件相关的公共方法主要是有防抖和节流2个,需要现在项目中导入eventBox 对象:

import { eventBox } from 'js-tool-big-box';

4.1 防抖

<template> <div> <input @keyup="handleChange" v-model="inputVal" /> </div></template> <script>import { eventBox } from 'js-tool-big-box'; export default { name: 'dj', data () { return { inputVal: '' } }, created() { this.myDebounce = eventBox.debounce((data) => { this.sendAjax(data); }, 2000); }, methods: { handleChange(event) { const val = event.target.value; this.myDebounce(val); }, sendAjax(data) { console.log('发送时间::', new Date().getTime()); console.log('发送请求:', data); }, }}</script>

4.2 节流

<script>import { eventBox } from 'js-tool-big-box'; export default { name: 'dj', data () { return { inputVal: '' } }, created() { this.myThrottle = eventBox.throttle((data) => { this.sendAjax(data); }, 2000); }, methods: { handleChange(event) { const val = event.target.value; this.myThrottle(val); }, sendAjax(data) { console.log('发送时间::', new Date().getTime()); console.log('发送请求:', data); }, }}</script>

5 Number相关方法学习

工具库也提供了Number相关的方法学习,需要先在项目中导入numberBox对象:

import { numberBox } from 'js-tool-big-box';

5.1 千分号分割

const num1 = numberBox.formatNumberWithCommas(13498345.333, 2);console.log('num1转化后:', num1); // 13,498,345.33const num11 = numberBox.formatNumberWithCommas(13498345.333);console.log('num11转化后:', num11); // 13,498,345

5.2 判断是否大于0

const num2 = numberBox.isGreater0('-33.23'); console.log('-33.23是大于0的数字吗?', num2); // false const num3 = numberBox.isGreater0('33.23s'); console.log('33.23s是大于0的数字吗?', num3); // false const num33 = numberBox.isGreater0(2024); console.log('2024是大于0的数字吗?', num33); // true

5.3 判断是否大于0的整数

const num4 = numberBox.isGreater0Integer('33.23'); console.log('33.23是大于0的整数吗?', num4); // false const num5 = numberBox.isGreater0Integer(99); console.log('99是大于0的整数吗?', num5); // true

5.4 生成指定范围内的随机数

// 生成80到100的随机整数const num6 = numberBox.getRandomNumber(80, 100);console.log('80到100的随机整数::', num6); // 86// 生成50到56并带有2位小数的随机数const num7 = numberBox.getRandomNumber(50, 56, 2);console.log('50到56并带有2位小数的随机数::', num7); // 55.57

5.5 生成指定位数的随机数

// 生成一个4位的随机数字const num66 = numberBox.generateUniqueRandomNumber(4);console.log('生成的4位的随机数字:', num66); // 6257// 生成一个6位的随机数字const num77 = numberBox.generateUniqueRandomNumber(6);console.log('生成的6位的随机数字:', num77); // 371420

5.6 数字转小写中文

const num8 = numberBox.numberToChinese('456788.12'); console.log('看一下456788.12的中文小写展示:', num8); const num9 = numberBox.numberToChinese(122456788.5); console.log('看一下122456788.5的中文小写展示:', num9);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (8)

5.7 数字转大写中文

const num10 = numberBox.numberToChinese(22456788.5, 'upper');console.log('看一下22456788.5的中文大写展示:', num10);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (9)

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (10)

6 字符串相关方法学习

字符串相关的方法呢,js-tool-big-box工具库对外提供了stringBox 对象,可供开发者使用:

import { stringBox } from 'js-tool-big-box';

6.1 字符串反转

const string1 = stringBox.reverseString('Hello, World!');console.log('需要反转的字符串::', string1);

6.2 横岗转小驼峰

const string2 = stringBox.hyphenToCamelCase('my-class-name', 'small');console.log('小驼峰转换::', string2);

6.3 横岗转大驼峰

const string3 = stringBox.hyphenToCamelCase('my-class-name', 'big');console.log('大驼峰转换::', string3);

6.4 版本号比较

const versionResult = stringBox.compareVersions('1.0.21', '1.0.12');console.log('1.0.21和1.0.12比较:', versionResult); // 1const versionResult1 = stringBox.compareVersions('1.2.21', '1.3.12');console.log('1.2.21和1.3.12比较:', versionResult1); // -1const versionResult2 = stringBox.compareVersions('1.1.3', '1.1.3.1');console.log('1.1.3和1.1.3.1比较:', versionResult2); // -1const versionResult3 = stringBox.compareVersions('1.1.3', '1.1.3');console.log('1.1.3和1.1.3比较:', versionResult3); // 0

6.5 获取字符串字节长度

注意:这里不是获取字符串的长度,是字节长度,注意区分

const str1 = 'Hello world!!!';const str2 = '我是The first one,😶 HaHa~';const str1ByteLength = stringBox.byteLength(str1);const str2ByteLength = stringBox.byteLength(str2);console.log('Hello world!!!的字节长度是:', str1ByteLength); // 14console.log('我是The first one,😶 HaHa~:', str2ByteLength); // 30

6.6 生成UUID

const myUUID1 = stringBox.generateUUID();console.log('获取到的uuid值第一次', myUUID1);// 8a556cd8-4c53-38dd-149d-38a32fe27cb9

6.7 通过身份证号获取生日、性别和年龄

const cardStr = '53010219200508011XF';const idCardObj = stringBox.getInfoByIdCard(cardStr);console.log('此人身份详情:', idCardObj);

6.8 字符串中间加星号遮盖

const cardStr = '53010219200508011X';const phone = '13344445555';const cardStrMask = stringBox.maskString(cardStr, 4, 4, '*', 6);const phoneMask = stringBox.maskString(phone, 4, 4, '*', 3);console.log('身份证号加星后为:', cardStrMask);console.log('手机号加星后为:', phoneMask);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (11)

7 正则验证相关方法学习

之前我们经常需要写正则表达式做一些验证,现在好了,我们有了公共方法,再也不用四处找去了,工具库提供了matchBox对象

import { matchBox } from 'js-tool-big-box';

7.1 邮箱验证

const email1 = '232322@qq.com';const email2 = '232322qq.ff';const emailResult1 = matchBox.email(email1);const emailResult2 = matchBox.email(email2);console.log('emailResult1验证结果:', emailResult1); // trueconsole.log('emailResult2验证结果:', emailResult2); // false

7.2 手机号验证

const phone1 = '13813313212'; const phone2 = '2381331320'; const phoneResult1 = matchBox.phone(phone1); const phoneResult2 = matchBox.phone(phone2); console.log('phoneResult1验证结果:', phoneResult1); // true console.log('phoneResult2验证结果:', phoneResult2); // false

7.3 url格式验证

const url1 = 'https://aa.test.com/user?q=3'; const url2 = '//33.co m/ user'; const urlResult1 = matchBox.url(url1); const urlResult2 = matchBox.url(url2); console.log('urlResult1验证结果:', urlResult1); // true console.log('urlResult2验证结果:', urlResult2); // false

7.4 身份证号码格式验证

const idCard1 = '120333199007712322x'; const idCard2 = '220333299007712322'; const idCardResult1 = matchBox.idCard(idCard1); const idCardResult2 = matchBox.idCard(idCard2); console.log('idCardResult1验证结果:', idCardResult1); // false console.log('idCardResult2验证结果:', idCardResult2); // true

7.5 IP地址格式验证

const ip1 = '192.168.1.111'; const ip2 = '333.168.299.0'; const ipResult1 = matchBox.ip(ip1); const ipResult2 = matchBox.ip(ip2); console.log('ipResult1验证结果:', ipResult1); // true console.log('ipResult2验证结果:', ipResult2); // false

7.6 邮政编码验证

const postal1 = '075616'; const postal2 = '956s6'; const postalResult1 = matchBox.postal(postal1); const postalResult2 = matchBox.postal(postal2); console.log('postalResult1验证结果:', postalResult1); // true console.log('postalResult2验证结果:', postalResult2); // false

7.7 是否Unicode字符

 const code1 = 'A'; const code2 = '😶'; const code3 = '🧚‍♂️'; const code1Result = matchBox.checkUnicode(code1); const code2Result = matchBox.checkUnicode(code2); const code3Result = matchBox.checkUnicode(code3); console.log('A是不是一个Unicode character?', code1Result); console.log('😶是不是一个Unicode character?', code2Result); console.log('🧚‍♂️是不是一个Unicode character?', code3Result);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (12)

8 发送请求相关

目前正常的Ajax还没有整理,fetch有自己的请求方法,很好用,所以这里只是封装了JSONP请求的公共方法,js-tool-big-box对外供了ajaxBox 对象供开发者使用:

import { ajaxBox } from 'js-tool-big-box';

8.1 发送JSONP跨域请求

ajaxBox.sendJSONP('http://127.0.0.1:3000/users/bar', 'callback', function(data){ console.log('获取到的JSONP请求数据', data);});

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (13)

9 data数据相关方法学习

data这里就内容会慢慢比较多,逐渐去丰富,工具库对外提供了dataBox 方法供开发者使用:

import { dataBox } from 'js-tool-big-box';

9.1 获取幸运者

const peopleData = '张三0, 张三1, 张三2, 张三3, 张三4, 张三5, 张三6, 张三7, 张三8, 张三9, 张三10, 张三11, 张三12, 张三13, 张三14, 张三15, 张三16, 张三17, 张三18, 张三19, 张三20, 张三21, 张三22, 张三23, 张三24, 张三25, 张三26, 张三27, 张三27, 张三29, 张三30, 张三31, 张三32, 张三33, 张三34, 张三35, 张三36, 张三37, 张三38, 张三39, 张三40';this.luckPeople = dataBox.luck(peopleData, 3);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (14)

9.2 复制文字到剪贴板

const text = '我在CSDN写工具,js-tool-big-box';dataBox.copyText(text, () => { // 复制成功后的业务逻辑 }, () => { // 复制异常后的业务逻辑 }

9.3 数组去重

const arr1 = [1, 2, 3, 5, 1, 2, 3, 4];const arr2 = [1, 2, 'jim', '1', 'tom', 1, '张三', 2, '3'];const uniqueArr1 = dataBox.uniqueArray(arr1);const uniqueArr2 = dataBox.uniqueArray(arr2);console.log('去重后的arr1的值为:', uniqueArr1);// [1, 2, 3, 5, 4]console.log('去重后的arr2的值为:', uniqueArr2);// [1, 2, 'jim', '1', 'tom', '张三', '3']

10 浏览器相关

公共方法,怎么能少的了浏览器相关的内容呢,js-tool-big-box对外提供了browserBox 对象供开发者使用:

import { browserBox } from 'js-tool-big-box';

10.1 判断是否手机端浏览器

const checkBrowser = browserBox.isMobileBrowser();console.log('当前是手机端浏览器吗?', checkBrowser);

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (15)

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (16)

10.2 检测某个元素是否处于可视范围内

mounted() { window.addEventListener('scroll', this.handleScroll); }, methods: { handleScroll() { const isInScreen = browserBox.isElementInViewport('.demo'); console.log('.demo在可视区域内吗?', isInScreen); }, }

最后

今天的javascript公共方法就总结到这里,已经上万字了,我为大家总结了js-tool-big-box的详细学习API和讲解说明,大家需要的可以去学习哦 :js-tool-big-box学习文档

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (17)

引领大型模型智能化革新:JS-Tool-Big-Box实践-CSDN博客 (2024)
Top Articles
Latest Posts
Article information

Author: Msgr. Benton Quitzon

Last Updated:

Views: 5810

Rating: 4.2 / 5 (43 voted)

Reviews: 90% of readers found this page helpful

Author information

Name: Msgr. Benton Quitzon

Birthday: 2001-08-13

Address: 96487 Kris Cliff, Teresiafurt, WI 95201

Phone: +9418513585781

Job: Senior Designer

Hobby: Calligraphy, Rowing, Vacation, Geocaching, Web surfing, Electronics, Electronics

Introduction: My name is Msgr. Benton Quitzon, I am a comfortable, charming, thankful, happy, adventurous, handsome, precious person who loves writing and wants to share my knowledge and understanding with you.