zoukankan      html  css  js  c++  java
  • 基于V2EX API的nodejs组件.

    今天又学习到了新的知(zi)识(shi),来给自己做个笔录,也算在这酷热的天气里给自己写了一篇降温的‘膏药’,话就讲这么多了 ,start off......

    首先 ,依赖选择:

    /**设置为严格模式*/
    'use strict';
    
    //引入依赖
    const https = require('https');
    const querystring = require('querystring');
    const util = require('util');

    下面代码块,可以理解为封装好的模块,创建命名为:V2exApi.js(此处随意),如何调用下面会讲到,go on......

    //定义类
    class V2exApi {
    
        /**
        * V2exApi constructor.
        */
        constructor() {
        }
    
        /**方案一 
        * @param string api
        * @param array  params
        * @param bool   $format
        *
        * @return mixed|string
        *
        * @throws HttpException
        */
        request(api, params = {}, $format = true) {
    
            let apiDomain = "https://www.v2ex.com/api/";
    
            //格式化地址
            let apiUrl = util.format(api, apiDomain, Object.keys(params).length > 0 ? querystring.stringify(params) : '');
            const result = "";
            https.get(apiUrl, res => {
                const buffer = [];
                res.on('data', data => {
                    buffer.push(data);
                });
                res.on('end', err => {
                    let data = Buffer.concat(buffer).toString('utf-8');
                    result = $format ? JSON.parse(data) : data;
                });
    
            }).on('error', err => {
                console.log(err);
            });
    
            return result;
        }
    
        /**方案二  异步  
            * @param string api
            * @param array  params
            * @param bool   $format
            *
            * @return mixed|string
            *
            * @throws HttpException
            */
        // request(api, params = {}, $format = true) {
    
        //     return new Promise(resolve => {
        //         //格式化请求地址
        //         let apiDomain = "https://www.v2ex.com/api/";
    
        //         let apiUrl = util.format(api, apiDomain, Object.keys(params).length > 0 ? querystring.stringify(params) : '');
        //         const result = "";
        //         https.get(apiUrl, res => {
        //             const buffer = [];
        //             res.on('data', data => {
        //                 buffer.push(data);
        //             });
        //             res.on('end', err => {
        //                 let data = Buffer.concat(buffer).toString('utf-8');
        //                 result = $format ? JSON.parse(data) : data;
        //                 resolve(result);
        //             });
    
        //         }).on('error', err => {
        //             resolve(err);
        //         });
        //     });
        // }
    
        /**
         * 获取最热主题.
         *
         * @param bool $format
         *
         * @return mixed|string
         *
         * @throws HttpException
         */
        getHotTopics($format = true) {
            return this.request('%stopics/hot.json', {}, $format);
        }
    
        /**
         * 获取最新主题.
         *
         * @param bool $format
         *
         * @return mixed|string
         *
         * @throws HttpException
         */
        getLatestTopics($format = true) {
            return this.request('%stopics/latest.json', {}, $format);
        }
    
        /**
         * 获取节点信息.
         *
         * @param string $name
         * @param bool   $format
         *
         * @return mixed|string
         *
         * @throws HttpException
         */
        getNode(name, $format = true) {
            return this.request('%snodes/show.json?%s', { 'name': name }, $format);
        }
    
        /**
         * 根据用户名获取用户信息.
         *
         * @param string $username
         * @param bool   $format
         *
         * @return mixed|string
         */
        getMemberByUsername(username, $format = true) {
            return this.request('%smembers/show.json?%s', { 'username': username }, $format);
        }
    
        /**
         * 根据用户 ID 获取用户信息.
         *
         * @param int  $id
         * @param bool $format
         *
         * @return mixed|string
         */
        getMemberByID(id, $format = true) {
            return this.request('%smembers/show.json?%s', { 'id': id }, $format);
        }
    }
    
    //暴露接口
    module.exports = V2exApi;
     
    ## 使用 
    在其它JS中引入下列:
    const V2exApi = require('./V2exApi');
    
    const $v2ex = new V2exApi();

    Example

    ### 获取最热主题

    方案一:
    response = $v2ex.getHotTopics();

    方案二 异步方法:
    response = $v2ex.getHotTopics().then(res => {
    //....
    }).catch(err => {
    //....
    });

    或者
    async function test () {
    response = await $v2ex.getHotTopics();
    }
    test();
     
    以上就是基于V2EX API的nodejs组件了,是不是很简单0.0..

    git源码地址:https://github.com/KelvinKey/v2ex-api

    V2EX API接口地址:https://www.v2ex.com/p/7v9TEc53

    End,努力做个多思考的人吧.

  • 相关阅读:
    P20 HTTP 方法的安全性与幂等性
    P19 查询参数
    P18 写代码:过滤和搜索
    P17 过滤和搜索
    P16 HTTP HEAD
    golang的json操作[转]
    Android中的Service 与 Thread 的区别[转]
    iOS的block内存管理
    Go并发编程基础(译)
    golang闭包里的坑
  • 原文地址:https://www.cnblogs.com/pingtouge/p/11263910.html
Copyright © 2011-2022 走看看