Promise解决回调地狱

105 阅读1分钟
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script src="./jquery-3.6.0.js"></script>
    <script>

        new Promise(
            function (resolve, reject) {
                $.ajax({
                    url: "回调.txt",
                    success: function (res) {
                        resolve(res)
                    },
                    error: function (err) {
                        reject(err)
                    }
                })

            }
        )
            .then(data => {
                console.log('then1:', data)
                return '地球'
            }, error => {
                console.log('catch1:', error)
            })
            .then(data => {
                console.log('then2:', data)
                return new Promise(resolve => {
                    $.ajax({
                        url: './huidiao.txt?name=' + data,
                        success: function (res) {
                            console.log('第二个请求拿到的洲的数据', res)
                            resolve('亚洲')
                        },
                        error: function (err) {

                        }
                    })
                })
            })
            .then(data => {
                console.log('then3:', data)
                return new Promise(resolve => {
                    $.ajax({
                        url: './huidiao3.txt?name=' + data,
                        success: function (res) {
                            console.log('第三个请求拿到最终的数据', res)
                        },
                        error: function (err) {
                        }
                    })
                })
            })
    </script>
</body>

</html>