当前位置:首页 > JavaScript

原生js异步实现

2026-03-15 19:45:44JavaScript

原生 JavaScript 异步实现方法

原生 JavaScript 提供了多种实现异步编程的方式,以下是常见的几种方法:

回调函数(Callbacks)

回调函数是异步编程最基础的方式,通过将函数作为参数传递给另一个函数,在异步操作完成后调用该函数。

function fetchData(callback) {
    setTimeout(() => {
        callback('Data received');
    }, 1000);
}

fetchData((data) => {
    console.log(data); // 输出: Data received
});

Promise

Promise 是 ES6 引入的异步编程解决方案,比回调函数更易于管理和避免回调地狱。

function fetchData() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            resolve('Data received');
        }, 1000);
    });
}

fetchData()
    .then(data => console.log(data)) // 输出: Data received
    .catch(error => console.error(error));

async/await

async/await 是 ES8 引入的语法糖,基于 Promise,使异步代码看起来像同步代码。

async function fetchData() {
    return new Promise((resolve) => {
        setTimeout(() => {
            resolve('Data received');
        }, 1000);
    });
}

async function main() {
    try {
        const data = await fetchData();
        console.log(data); // 输出: Data received
    } catch (error) {
        console.error(error);
    }
}

main();

事件监听(Event Listeners)

通过事件监听实现异步,常用于 DOM 事件或自定义事件。

document.getElementById('button').addEventListener('click', () => {
    console.log('Button clicked');
});

setTimeout 和 setInterval

定时器函数用于延迟执行或周期性执行代码。

setTimeout(() => {
    console.log('Executed after 1 second');
}, 1000);

setInterval(() => {
    console.log('Executed every 1 second');
}, 1000);

Generator 函数

Generator 函数是 ES6 引入的另一种异步编程方式,通过 yield 暂停执行。

原生js异步实现

function* fetchData() {
    yield new Promise(resolve => {
        setTimeout(() => {
            resolve('Data received');
        }, 1000);
    });
}

const generator = fetchData();
generator.next().value.then(data => console.log(data)); // 输出: Data received

选择合适的方法

  • 简单异步任务:回调函数或 Promise。
  • 复杂异步逻辑:async/await 或 Promise 链。
  • 事件驱动场景:事件监听。
  • 定时任务setTimeoutsetInterval
  • 高级控制流程:Generator 函数。

每种方法各有优劣,根据具体场景选择最合适的实现方式。

标签: js
分享给朋友:

相关文章

原生js实现轮播图

原生js实现轮播图

基本结构搭建 HTML部分需要包含轮播图容器、图片列表及导航按钮。结构示例如下: <div class="slider-container"> <div class="slid…

js实现换肤

js实现换肤

使用CSS变量实现换肤 通过CSS变量可以轻松实现主题切换功能。CSS变量在根元素中定义,通过JavaScript动态修改这些变量值。 :root { --primary-color: #349…

js实现驼峰

js实现驼峰

实现驼峰命名的几种方法 使用正则表达式和字符串替换 通过正则表达式匹配字符串中的特定模式(如下划线或短横线),并将其后的字母转换为大写,同时移除分隔符。 function toCamelCase(s…

js手势实现

js手势实现

手势识别实现方法 在JavaScript中实现手势识别通常涉及监听触摸事件(touchstart、touchmove、touchend)或鼠标事件(mousedown、mousemove、mouseu…

js实现代码雨

js实现代码雨

实现代码雨效果 使用HTML5 Canvas和JavaScript可以轻松实现经典的代码雨效果。以下是完整的实现代码和说明: HTML结构 <!DOCTYPE html> <htm…

js实现图片放大

js实现图片放大

使用 CSS transform 实现图片放大 通过 CSS 的 transform: scale() 属性实现图片放大效果。当鼠标悬停时,图片会平滑放大。 const img = document…