HTML Superlative Compare Game Data Attributes Tutorial
โœ‚๐Ÿƒ๐Ÿพโ€โ™€๏ธ๐Ÿƒ๐Ÿผโ€โ™‚๏ธ
๐Ÿ“–

HTML Superlative Compare Game Data Attributes Tutorial

HTML Superlative Compare Game Data Attributes Tutorial

Yesterdayโ€™s web application game โ€œSubject Areasโ€ of HTML/Javascript Subject Areas Game Data Attributes Tutorial, as shown below, came in very handy as the starting point for the design and a large part of the workflow and coding of todayโ€™s โ€œComparisons and Superlativesโ€ game, again primarily designed for testing and/or improving some question sentence construction skills for ESL (or โ€œEnglish as a Second or Foreign Languageโ€) students. Itโ€™s easy to ask the questions, but getting the computer to answer โ€ฆ Gooooooooooogggggggglllllllleeeee?!

So itโ€™s big โ€ฆ bigger โ€ฆ biggest types of thinking with the game today, where the subject word(s) (where the rest of the (question) sentence (we were taught at school, in English grammar, is the predicate)) is matched by the user, interactively, with a suitable โ€ฆ

  • comparative adjective โ€ฆ eg. taller โ€ฆ or โ€ฆ
  • superlative adjective โ€ฆ eg. (the) tallest

โ€ฆ along with a loose sanity check on sense, and then the user proceeds to also define a suitable โ€ฆ

  • comparison object word(s) โ€ฆ and optionally โ€ฆ
  • (additional) superlative object word(s) (prefixed by โ€ and โ€œ)

In doing this, and seeing the (question) sentences work, or not, you see that it is an โ€œobjectโ€ at play here, because where we have โ€œsubjectโ€ pronouns in the left hand list, by the time we want them to work in the right hand dropdown list of potential โ€œobjectโ€ pronouns we had to change their form, to have the (question) sentences be well formed sentences. An example here is the โ€œsheโ€ (as a subject) on the left hand column becomes โ€œherโ€ (as an object) on the right hand dropdown list. This happens less with โ€œsubjectโ€ nouns.

So why not try our liveโœ‚run or peruse the HTML and Javascript code behind its operation with compared_toโšซhtm today?

Before we go, a catch up on thank yous to .. by Penny Ur and Andrew Wright โ€ฆ ISBN: 978-0-521-39781-0 โ€ฆ

  • Page 9 for todayโ€™s Superlative Comparing game โ€ฆ and โ€ฆ
  • Page 54 for inspiration for yesterdayโ€™s Subject Areas game


Previous relevant HTML/Javascript Subject Areas Game Data Attributes Tutorial is shown below.

HTML/Javascript Subject Areas Game Data Attributes Tutorial

HTML/Javascript Subject Areas Game Data Attributes Tutorial

Yesterdayโ€™s web application game โ€œSubject Areasโ€ which we started with HTML/Javascript Subject Areas Game Tutorial had a weakness in โ€œUXโ€ terms, and only for non-mobile platforms where onmouseover event means something โ€ฆ but a weakness nonetheless. Perhaps it is good to develop a sense of such issues annoying you, and that way you learn things.

So what are the specifics of this โ€œweaknessโ€ (for non-mobile users)? The dropdown being hovered on, in the old ways of yesterday, can give the game away, and make it too easy for the user to get the answer with no โ€œthinkingโ€ effort. The reason this has happened is due to the โ€œold wayโ€ of adding a title property to all of the HTML option elements, that we use in a true data sense to make our game work โ€ฆ but nonetheless is the โ€œweaknessโ€ we can remedy โ€ฆ with โ€ฆ data attributes and weโ€™ve talked about this before at XML to HTML PHP Three Ways Translation Tutorial. And donโ€™t want to come over all school masterish โ€˜n all, but โ€ฆ and isnโ€™t there always a butt โ€ฆ but this is an important aspect to adding data intelligence to your HTML work, and it doesnโ€™t surprise me that in the title of that time we talked about it before there is โ€œXMLโ€ mentioned. XML normally has a lot of data intelligence, but data attributes can help you get towards some of that with your HTML web application work. Specifically, HTML/Javascript code-wise โ€ฆ we โ€ฆ

  • used to, with HTML option elements, using the title property โ€ฆ
    1. define via โ€ฆ


      selinnards += "<option title='" + ourwordlist[i].split(';')[1] + "' value='" + ourwordlist[i].split(';')[0] + "'>" + ourwordlist[i].split(';')[0] + "</option>";

    2. reference via โ€ฆ


      if ((',' + selo.options[selo.selectedIndex].title + ',').indexOf((',' + versus + ',')) != -1) {

      // more code here

      }

  • โ€ฆ versus โ€ฆ we now, with HTML option elements, using the data attribute โ€œhomespunโ€ data-title data attribute โ€ฆ
    1. define via โ€ฆ


      selinnards += "<option data-title='" + ourwordlist[i].split(';')[1] + "' value='" + ourwordlist[i].split(';')[0] + "'>" + ourwordlist[i].split(';')[0] + "</option>";

    2. reference via โ€ฆ


      if ((',' + selo.options[selo.selectedIndex].getAttribute('data-title') + ',').indexOf((',' + versus + ',')) != -1) {

      // more code here

      }

Try our liveโœ‚run (and/or compare it to the oldโœ‚ways live run) or peruse the HTML and Javascript code behind its operation with subject_areasโšซhtml today, changed from yesterday in thisway. Now you may notice examining this code, it does not exactly look as above, but this code above was working (and would still work) after an epiphany we had โ€ฆ but please donโ€™t spread this epiphany around โ€ฆ especially on dry rye bread โ€ฆ that non-mobile users can have an improved game working this idea above, because there are probably ESL students, or others, who may want the hints that the onmouseover title property usage give, so how about we add a degree of difficulty concept to the game, for them, via โ€ฆ

  • as new global variables โ€ฆ


    var mode='difficult';

    var modeprefix='data-';

  • at onload event (unchanged code) but changed HTML just below that โ€ฆ


    <body onload=" fillintable(0,''); " style="background-color:aqua;">

    <h1>Subject Areas <div id='ifnm' style=display:inline;></div> <a title='Your Own Subject Area' style='text-decoration:underline;cursor:pointer;' onclick='ask();'>+</a></h1>

  • and at fillintable(0,โ€) call of function, the new code โ€ฆ


    function locy(thisvalue) {

    location.href='./subject_areas.htm?score=' + score + '&goes=' + goes + '&difficulty=' + thisvalue;

    }



    function fillintable(phase,addthis) {

    var i,j,thisrow="",thesewords,k,selinnards='';

    if (phase == 0) {

    mode=location.search.split('difficulty=')[1] ? location.search.split('difficulty=')[1].split('&')[0] : 'difficult';

    if (navigator.userAgent.match(/Android|BlackBerry|iPhone|iPad|iPod|Opera Mini|IEMobile/i)) {

    phase=phase;

    } else if (mode.replace('difficult','') != '') {

    modeprefix='';

    document.getElementById('ifnm').innerHTML='<select onchange=" locy(this.value); "><option value=easy>Hints (on hover) Game</option><option value=difficult>No Hints Game</option></select>';

    } else {

    document.getElementById('ifnm').innerHTML='<select onchange=" locy(this.value); "><option value=difficult>No Hints Game</option><option value=easy>Hints (on hover) Game</option></select>';

    }


    var addit=location.search.split('addthis=')[1] ? decodeURIComponent(location.search.split('addthis=')[1]).split('&')[0] : '';

  • and at the define, the code ideas coalesce, via โ€ฆ


    selinnards += "<option " + modeprefix + "title='" + ourwordlist[i].split(';')[1] + "' value='" + ourwordlist[i].split(';')[0] + "'>" + ourwordlist[i].split(';')[0] + "</option>";

  • and at the reference, the code ideas coalesce, via โ€ฆ


    if ((',' + selo.options[selo.selectedIndex].getAttribute(modeprefix + 'title') + ',').indexOf((',' + versus + ',')) != -1) {

    // more code here

    }

As you can see, we really like Javascript global variables, but if you are like us in this way, be aware that this is not such a popular opinion.


Previous relevant HTML/Javascript Subject Areas Game Tutorial is shown below.

HTML/Javascript Homonymns Game Tutorial

HTML/Javascript Subject Areas Game Tutorial

Weโ€™ve called todayโ€™s web application game โ€œSubject Areasโ€, primarily designed for testing and/or improving the vocabulary skills for ESL (or โ€œEnglish as a Second or Foreign Languageโ€) students.

We humans love to categorize things, and today, with this game of ours, we are facilitating that penchant we have by our โ€œcategoriesโ€ being โ€œSubjectsโ€, like at school or in life, and the user of the game is asked to look down a list of words to pick ones where the word has a synergy with the โ€œSubjectโ€. They score a point if we agree, and donโ€™t think we donโ€™t know if you cheat?!!?!?

So why not try our liveโœ‚run (which, today, acts differently to the web application that happens when you click the tutorial picture โ€ฆ more on that tomorrow, if you canโ€™t guess it yourself?!) or peruse the HTML and Javascript code behind its operation with subject_areasโšซhtml today (or at WordPress 4.1.1โ€™s HTML/Javascript Subject Areas Game Tutorial)? That wasnโ€™t rhetorical, was it?!

If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.


If this was interesting you may be interested in this too.

This entry was posted in eLearning, ESL, Games, Tutorials and tagged , , , , , , , , , , , , , , , , , , , , , , , , , . Bookmark the permalink.

Leave a Reply

Your email address will not be published. Required fields are marked *