本文实例为大家分享了JavaScript node实现三级联动菜单的具体代码,供大家参考,具体内容如下

项目分析

1、效果

2、前端

=>面向对象

=>首先分析下拉结构,构造相应的结构和样式

=>绑定事件,点击,鼠标滑过等

=>导入写好的 js 文件 构造菜单项、

=>使用ajax请求服务端 获取数据

=>用每次获取的数据动态生成页面结构

3、服务端

=>接口文档(定义接口,服务地址,端口}

=>存储数据

=>创建服务器

=>接收前端的ajax请求,响应数据

代码

1、面向对象代码

export default class Select{
    //添加css样式
    static  addCSS(selector,style,title){
        if(title===undefined) title="xietian";
        var arr=Array.from(document.styleSheets);
        var  styleSheet=arr.reduce(function(value,item){
            if(item.title===title)return item;
            return value;
        },null);
        if(!styleSheet){
            var s=document.createElement("style");
            s.title=title;
            document.head.appendChild(s);
            styleSheet=document.styleSheets[document.styleSheets.length-1];
        }
        var str="";
        for(var prop in style){
            str =prop.replace(/[A-Z]/g,function(value){
                return "-" value.toLowerCase();
            }) ":" (typeof style[prop]==="number" ? style[prop] "px" : style[prop]) ";";
        }
        if(styleSheet.addRule){
            styleSheet.addRule(selector,str,styleSheet.cssRules.length);
        }else{
            styleSheet.insertRule(selector "{ " str " }",styleSheet.cssRules.length);
        }
    }

//定义全局变量
    button;
    ul;
    class;
    constructor(parent,_class) {
        // this.id = _id;
        this.class = _class;
        this.elem = this.createEle();
        this.appendTo(parent);
    }
    //创建元素
    createEle() {
        const div = document.createElement('div');
        div.className = "dropdown "   this.class;
        this.button = document.createElement('button');
        this.button.className = "btn btn-default dropdown-toggle";
        this.button.addEventListener('click',e=>this.clickHander(e))
        this.content = document.createElement('span');
        this.content.innerText = "请选择";
        const carte = document.createElement('span');
        this.content.className = 'content';
        carte.className = 'carte';
        this.button.appendChild(this.content);
        this.button.appendChild(carte);
        this.ul = document.createElement('ul');
        this.ul.className = "dropdown-menu";
        this.button.appendChild(this.ul);
        div.appendChild(this.button)
        return div;
    }
    //添加点击事件
    clickHander(e) {
        this.ul.classList.toggle('on');
    }
   //增加li
    addli(list) {
        if(!list) return;
        const frg = document.createDocumentFragment();
        list.forEach(item=>{
            const li = document.createElement('li');
            li.innerHTML = item;
            li.addEventListener('click',e=>this.liHandler(e));

            frg.appendChild(li);
        })
        this.ul.appendChild(frg);
    }
    //给li添加的点击事件
    liHandler(e) {
        this.content.innerHTML = e.target.innerText;

    }
    //添加css样式
    addCSS() {
        Select.addCSS(".dropdown",{
            position: "relative",
            boxSizing: "border-box",
            width: "8.33333333%",
            display:"inline-block",
            minHeight: "1px",
            paddingRight: "15px",
            paddingLeft: "15px",
            fontSize: "14px",
            lineHeight: "1.42857143",
            color: "#333333",
        })
        Select.addCSS(".btn",{
            display:'inlineBlock',
            marginBottom:'0',
            outline:"none",
            fontWeight:'normal',
            textAlign:'center',
            whiteSpace:'nowrap',
            verticalAlign:'middle',
            touchAction:'manipulation',
            cursor:'pointer',
            backgroundImage:'none',
            border:'1px solid transparent',
            padding:'6px 12px',
            fontSize:'14px',
            lineHeight:'1.42857143',
            borderRadius:'4px',
            userSelect:'none',
        })
        Select.addCSS(".btn-default",{
           color:'#333',
            backgroundColor:'#fff',
            borderColor:'#ccc',
        })
        Select.addCSS(".btn-default:hover",{
            color:'#333',
            backgroundColor:'#e6e6e6',
            borderColor:'#adadad',
        })
        Select.addCSS(".carte",{
            display:'inline-block',
            width:'0',
            marginLeft: "0",
            height:'0',
            verticalAlign:'middle',
            borderTop:'4px dashed',
            borderRight:'4px solid transparent',
            borderLeft:'4px solid transparent',
        })
        Select.addCSS(".dropdown-menu",{
            position:'absolute',
            top:'100%',
            left:'15px',
            height:'200px',
            overflowY:'scroll',
            zIndex:'1000',
            display:'none',
            float:'left',
            minWidth:'83px',
            padding:'5px 0',
            margin:'2px 0 0',
            fontSize:'14px',
            textAlign:'left',
            listStyle:'none',
            backgroundColor:'#fff',
            backgroundClip:'paddingBox',
            border:'1px solid #ccc',
            border:'1px solid rgba(0, 0, 0, 0.15)',
            borderRadius:'4px',
            boxShadow:'0 6px 12px rgba(0, 0, 0, 0.175)',
        
        })
        Select.addCSS(".on", {
            display:"block!important",
        })
        Select.addCSS('li',{
            textAlign:"center",
        })
        Select.addCSS('li:hover',{
            backgroundColor:'#e6e6e6',
        })
    }
    //添加到html结构中的位置
    appendTo(parent) {
        if(typeof parent == 'string') parent=document.querySelector(parent);
        parent.appendChild(this.elem);
        this.addCSS();
    }

}

2、向服务器请求ajax

<script type="module">
        import Select from "./select.js";
        // var list = ["北京","上海","广州","深圳","武汉"];

        let citylist,provincelist,countylist,province_content,content_county;

        var sel_p = new Select('.box','province');

        ajax("city.json",(res)=>{
             provincelist = Object.keys(res);
            sel_p.addli(provincelist);
            sel_p.elem.addEventListener('click',clickHandler)
         province_content = document.querySelector('.province .content');
            county() 
        })

        var sel_c = new Select('.box','city');

        function clickHandler(e) {
            if(e.target.constructor!== HTMLLIElement) return;
            ajax(`http://10.9.72.252:4001/province/?province=${e.target.innerText.trim()}`,function(res){
                 citylist = Object.keys(res.city)
                sel_c.addli(citylist);
                const province = document.querySelector('.province ul');
                province.addEventListener('click',cityHandler);
            })
        }
        

        function cityHandler(e) {
            const content_city = document.querySelector('.city .content');
            const li = document.querySelectorAll('.city li');
            const content_county  = document.querySelector('.county .content');
            content_county.innerText=content_city.innerText = "请选择";
            li.forEach(item=>{
                item.remove();
            })
        }
            //获取区县数据
       function county() {
           var sel_conuty = new Select('.box','county');
           sel_c.elem.addEventListener('click',e=>{
            if(e.target.constructor!== HTMLLIElement) return;
            ajax(`http://10.9.72.252:4001/city/?province=${province_content.innerText.trim()}&city=${e.target.innerText.trim()}`,function(res){
                // console.log(res); 
                countylist =res.county
                sel_conuty.addli(countylist);
                const city = document.querySelector('.city ul');
                city.addEventListener('click',countyHandler);
            })
           })
       }    
        
       function countyHandler(e) {
        const lis = document.querySelectorAll('.county li');
        const content_coun = document.querySelector('.county .content');
        content_coun.innerText = "请选择";
        lis.forEach(item=>{
                item.remove();
            })

       }
       //封装一个简单的
        function ajax(url, fn) {
                // XMLHttpRequest对象用于在后台与服务器交换数据
                var xhr = new XMLHttpRequest();
                xhr.open('GET', url, true)
                xhr.onreadystatechange = function () {
                    if(xhr.readyState == 4 && xhr.status ==200) {
                        //从服务器获得数据
                        fn.call(this, JSON.parse(xhr.responseText));
                    }
                };
                //发送数据
                xhr.send();
            }
</script>

3、服务端

const http = require('http');
const querystring= require('querystring');
const city = require("../city.json");
const server = http.createServer(function(req, res) {
    res.writeHead(200,{
        "content-type":"text/html;charset=utf-8",
        "Access-Control-Allow-Origin":"*",
        "Access-Control-Allow-Headers":"*",
        //请求头跨域 如果请求头发生修改并且非同源,就需要申请请求头跨域
    });
    req.on('data',function(_data) {
        data=_data
    })
    req.on('end',function () {
        // type是接口名称
        console.log(req.url);
        var type=req.url.trim().split("?")[0].replace(/\//g,"");
        console.log(type);
        if(req.method.toLowerCase()==="get"){
            if(req.url.includes("favicon.ico")) return res.end();//如果get请求的是图标直接返回空跳出
            // 如果是get请求,就从url中重新获取数据存入data变量
            data=req.url.includes("?") ? req.url.split("?")[1] : "";
        }
        // 首先判断是否可以通过JSON解析,如果通过JSON直接转换,如果不能就是querystring解析
        try{
            data=JSON.parse(data);
        }catch(e){
            data=data ? querystring.parse(data) : {};
            console.log(data);

        }
        let o = {}
        switch(type){
            case 'province':
                o = {};
                o.city = obj[data.province];
                break;
            case 'city':
                o.city = obj[data.province];
                o.county = o.city[data.city];
                break;
        }
        res.write(JSON.stringify(o));
        res.end();
    })
})
//监听4001端口
server.listen(4001,"你的地址",function() {
    console.log("服务器开启成功^_^");
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Devmax。

JavaScript+node实现三级联动菜单的更多相关文章

  1. html5 拖拽及用 js 实现拖拽功能的示例代码

    这篇文章主要介绍了html5 拖拽及用 js 实现拖拽,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. amaze ui 的使用详细教程

    这篇文章主要介绍了amaze ui 的使用详细教程,本文通过多种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. xcode – 如何在Interface Builder中为NSMenu添加其他项目?

    我第一次使用Xcode.我一直在追踪一个教程,我完全被一些毫无疑问的东西所吸引.我将“菜单”从库拖动到“MainMenu.xib”窗口中.双击此菜单可使其显示.没有麻烦到目前为止.编辑这三个项目是直观的,正如删除项目一样.但是,如何添加一个项目到这个菜单呢?解决方法您想将一个NSMenuItem从库托盘拖到菜单上:您可以添加子菜单和分隔符.

  4. swift皮筋弹动发射飞机ios源码

    这是一个款采用swift实现的皮筋弹动发射飞机游戏源码,游戏源码比较详细,大家可以研究学习一下吧。

  5. Swift实现侧滑菜单SWRevealViewController

    SWRevealViewControllerGithub下载地址导入我这里直接新建一个SWRevealViewController包,然后把代码直接粘贴进入在桥接文件中导入#import“SWRevealViewController.h”使用编译一下,接着新建一个MainController父容器,继承SWRevealViewController创建左侧菜单栏RightMenuController

  6. Swift与Js通过WebView交互

    开发环境:Swfit2.3XCode8.2基础概念jscontext,jscontext是代表JS的执行环境,通过-evaluateScript:方法就可以执行一JS代码JSValue,JSValue封装了JS与ObjC中的对应的类型,以及调用JS的API等JSExport,JSExport是一个协议,遵守此协议,就可以定义我们自己的协议,在协议中声明的API都会在JS中暴露出来,才能调用Swif

  7. JSCore swift

    如果双方相互引用,会造成循环引用,而导致内存泄露。以上是Jscore的基本使用,比较简单

  8. Swift WKWebView的js调用swift

    最近项目需求,需要用到JavaScriptCore和WebKit,但是网上的资源有限,而且比较杂,都是一个博客复制另外一个博客,都没有去实际敲代码验证,下面给大家分享一下我的学习过程。

  9. Swift WKWebView的swift调用js

    不多说,直接上代码:在html里面要添加的的代码,显示swift传过去的参数:这样就实现了swift给js传参数和调用!

  10. 在 Swift 專案中使用 Javascript:編寫一個將 Markdown 轉為 HTML 的編輯器

    你有強烈的好奇心,希望在你的iOS專案中使用JavaScript。jscontext中的所有值都是JSValue對象,JSValue類用於表示任意類型的JavaScript值。因此,我們既需要寫Swift代碼也要寫JavaScript代碼。此外,我們還會在JavaScript中按照這個類的定義來創建一個對象并對其屬性進行賦值。從Swift中呼叫JavaScript就如介紹中所言,JavaScriptCore中最主要的角色就是jscontext類。一個jscontext對象是位於JavaScript環境和本

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部