search
HomeWeb Front-endJS TutorialUse javascript to make a general wizard_javascript skills

1. Interface design
index.html: only provides a placeholder for the wizard display position

Copy code The code is as follows :



Gift Recommendation Guide










style.css: By default, the wizard has a title presented by h2, a main content presented by ul, and a button bar presented by div. We simply designed their default appearance. In actual application, you can Feel free to embellish them.
Copy code The code is as follows:

body{
margin:0;
}
/*wizard container*/
#wizard{
height:400px;
width:600px;
background-color:#999;
}
/*wizard The main content is displayed in a list*/
#wizard ul{
margin:10px;
height:80%;
}
/*Display list content horizontally*/
# wizard li{
display:inline-block;
margin:10px;
cursor:pointer;
}
/*Title of the list*/
#wizard h2{
margin:10px;
}
/*The function bar of the list, such as the back button*/
#wizard .bar{
margin:10px;
clear:both;
}

2. Prepare each step

The wizard can be divided into each step. Each step needs to present content, capture user selections, provide titles and other functions. We make each step its own You are responsible for your own affairs, but you must comply with some contracts stipulated by us.

Each step is represented by a function. The first parameter data_key is the keyword to select the data of this step. It is generally used to determine the result of the previous step to display the data in the next step. The second parameter result_callback It is a callback function, which is called when the result is obtained in this step. It is used to communicate with the wizard class. After getting the result of the previous step, the wizard class stores the result and jumps to the next step.

This function returns a tuple, the first element is the title of this step, and the second element is the UI of the main part of this step.

Our example is a gift recommendation system, which is divided into three steps. The first step is to select the gift recipient, and the second step is to select the keyword. The selection result of the first step will affect the display of the second step. Select the price range in three steps. The following is the implementation of the code. The drawing interface and event capture use jquery to simplify the operation.
Copy code The code is as follows:

function step1(data_key, result_callback){
var targets = ['girlfriend','boyfriend','father','mom','child'];
var warpper = $('
    ')
    $ .each(targets, function(k,v){
    $('
  • ' v '
  • ').click(function(){result_callback(v)}).appendTo(warpper) ;
    });
    return ['Step 1: Please choose the recipient of the gift',warpper];
    }
    function step2(data_key, result_callback){
    var tags = {
    'Girlfriend': ['creative', 'cute', 'romantic', 'passion', 'practical', 'digital',
    'self-made', 'plush toys', 'clothes', 'bag'],
    'boyfriend':['men's products','warmth','practical','digital','creative','clothing'],
    'father':[' Men's products','health','plants','clothing'],
    'Mom':['warmth','health','creative','skin care','practical'],
    'Kids' :['Toys','School Supplies','Practical','Digital']
    };
    var warpper = $('
      ')
      $.each(tags[data_key], function(k,v){
      $('
    • ' v '
    • ').click(function(){result_callback(v)}). appendTo(warpper);
      });
      return ['Step 2: Please select the keyword',warpper];
      }
      function step3(data_key, result_callback){
      var price_level = ['cheap', 'ordinary', 'slightly expensive', 'expensive'];
      var wrapper = $('
        ')
        $.each(price_level, function (k,v){
        $('
      • ' v '
      • ').click(function(){result_callback(v)}).appendTo(warpper);
        }) ;
        return ['Step 3: Please select a price range',warpper];
        }

        3. Implementation of the wizard class

        The wizard class should set the DOM element where the wizard is located, the list of steps to be executed, the callback to be executed after the wizard is completed, and the wizard should also provide methods for the previous step and the next step. So we use a class to represent the wizard, pass in the DOM container, step list and callback function in the constructor, and use prototype to add three methods to the class. Render is used to present the UI of a certain step and push it to the next step in the callback of the collected results of this step. If this step is the last step, the callback function of the completion of the wizard execution is called.

        The other two next and back functions are to execute the previous step and the next step respectively. These two functions use the private variables of index to maintain the state of the entire wizard
        Copy code The code is as follows:

        function Wizard(container, steps, callback){
        this.container = container; //Wizard container
        this.steps = steps; //Wizard steps
        this.callback = callback; //Callback after the wizard is executed
        this.collect_data = []; //Save the results of each step of the wizard
        this.index = -1; //Which step is currently executed
        }
        //Draw a certain step
        Wizard.prototype.render = function(step, this_result){
        var me = this;
        //Execute this step and get the UI of this step
        var to_append = step(this_result,function(result){
        me.collect_data.push(result); //Collect this step Result
        //The callback function is called when the wizard is completed, otherwise the next step is executed
        if(me.collect_data.length == me.steps.length)
        me.callback(me.collect_data);
        else
        me.next(result);
        });
        //Draw the UI for this step
        this.container.empty();
        this.container.append("< ;h2>" to_append[0] "");
        this.container.append(to_append[1]);
        if(this.index > 0){
        // Back Button
        this.container.append($("")
        .click(function(){me.back()}
        ));
        }
        }
        //Execute the next step
        Wizard.prototype.next = function(this_result) {
        if(this.index >= this.steps.length -1)
        return;
        var step = this.steps[ this.index];
        this.render(step,this_result );
        }
        //Go back to the previous step
        Wizard.prototype.back = function(){
        if(this.index return;
        var step = this.steps[--this.index];
        //The step returns to the previous step, but the data of the previous step needs to be determined by the result of the previous step
        this.collect_data = this.collect_data.slice( 0, this.index);
        this.render(step, this.collect_data[this.index - 1]);
        }

        4. Summary

        This wizard has a simple structure and is highly customizable. It combines the functional programming features and object-oriented features of JavaScript, reflecting the power and convenience of JavaScript.

        There is still some coupling between the interface drawing part in the wizard class and the interface drawing part in the step function. If we continue to refactor, we can abstract all the interface drawing parts together to make interface changes more convenient.
        Statement
        The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
        Replace String Characters in JavaScriptReplace String Characters in JavaScriptMar 11, 2025 am 12:07 AM

        Detailed explanation of JavaScript string replacement method and FAQ This article will explore two ways to replace string characters in JavaScript: internal JavaScript code and internal HTML for web pages. Replace string inside JavaScript code The most direct way is to use the replace() method: str = str.replace("find","replace"); This method replaces only the first match. To replace all matches, use a regular expression and add the global flag g: str = str.replace(/fi

        Build Your Own AJAX Web ApplicationsBuild Your Own AJAX Web ApplicationsMar 09, 2025 am 12:11 AM

        So here you are, ready to learn all about this thing called AJAX. But, what exactly is it? The term AJAX refers to a loose grouping of technologies that are used to create dynamic, interactive web content. The term AJAX, originally coined by Jesse J

        10 jQuery Fun and Games Plugins10 jQuery Fun and Games PluginsMar 08, 2025 am 12:42 AM

        10 fun jQuery game plugins to make your website more attractive and enhance user stickiness! While Flash is still the best software for developing casual web games, jQuery can also create surprising effects, and while not comparable to pure action Flash games, in some cases you can also have unexpected fun in your browser. jQuery tic toe game The "Hello world" of game programming now has a jQuery version. Source code jQuery Crazy Word Composition Game This is a fill-in-the-blank game, and it can produce some weird results due to not knowing the context of the word. Source code jQuery mine sweeping game

        How do I create and publish my own JavaScript libraries?How do I create and publish my own JavaScript libraries?Mar 18, 2025 pm 03:12 PM

        Article discusses creating, publishing, and maintaining JavaScript libraries, focusing on planning, development, testing, documentation, and promotion strategies.

        jQuery Parallax Tutorial - Animated Header BackgroundjQuery Parallax Tutorial - Animated Header BackgroundMar 08, 2025 am 12:39 AM

        This tutorial demonstrates how to create a captivating parallax background effect using jQuery. We'll build a header banner with layered images that create a stunning visual depth. The updated plugin works with jQuery 1.6.4 and later. Download the

        How do I optimize JavaScript code for performance in the browser?How do I optimize JavaScript code for performance in the browser?Mar 18, 2025 pm 03:14 PM

        The article discusses strategies for optimizing JavaScript performance in browsers, focusing on reducing execution time and minimizing impact on page load speed.

        Auto Refresh Div Content Using jQuery and AJAXAuto Refresh Div Content Using jQuery and AJAXMar 08, 2025 am 12:58 AM

        This article demonstrates how to automatically refresh a div's content every 5 seconds using jQuery and AJAX. The example fetches and displays the latest blog posts from an RSS feed, along with the last refresh timestamp. A loading image is optiona

        Getting Started With Matter.js: IntroductionGetting Started With Matter.js: IntroductionMar 08, 2025 am 12:53 AM

        Matter.js is a 2D rigid body physics engine written in JavaScript. This library can help you easily simulate 2D physics in your browser. It provides many features, such as the ability to create rigid bodies and assign physical properties such as mass, area, or density. You can also simulate different types of collisions and forces, such as gravity friction. Matter.js supports all mainstream browsers. Additionally, it is suitable for mobile devices as it detects touches and is responsive. All of these features make it worth your time to learn how to use the engine, as this makes it easy to create a physics-based 2D game or simulation. In this tutorial, I will cover the basics of this library, including its installation and usage, and provide a

        See all articles

        Hot AI Tools

        Undresser.AI Undress

        Undresser.AI Undress

        AI-powered app for creating realistic nude photos

        AI Clothes Remover

        AI Clothes Remover

        Online AI tool for removing clothes from photos.

        Undress AI Tool

        Undress AI Tool

        Undress images for free

        Clothoff.io

        Clothoff.io

        AI clothes remover

        AI Hentai Generator

        AI Hentai Generator

        Generate AI Hentai for free.

        Hot Article

        R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
        2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
        R.E.P.O. Best Graphic Settings
        2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
        R.E.P.O. How to Fix Audio if You Can't Hear Anyone
        2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

        Hot Tools

        VSCode Windows 64-bit Download

        VSCode Windows 64-bit Download

        A free and powerful IDE editor launched by Microsoft

        SublimeText3 Mac version

        SublimeText3 Mac version

        God-level code editing software (SublimeText3)

        EditPlus Chinese cracked version

        EditPlus Chinese cracked version

        Small size, syntax highlighting, does not support code prompt function

        MantisBT

        MantisBT

        Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

        mPDF

        mPDF

        mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),