Solved

How can I use jquery to parse out parameters from an encoded url with custom separators and place them into a string with pre-defined positions?

Posted on 2014-11-19
7
342 Views
Last Modified: 2014-11-22
My goal is to extract values from name-value pairs within a URL and return those values into a string that can be inserted into a web tracking tag.  Th using a js function. The string has fifteen positions separated by "-_-".  No matter where each name-value pair appears within the URL, values most always be inserted into the same position within the tracking tag string.  For example, the value(s) for the name apple must always appear in the first position, the value(s) for the name banana must always appear in the second position, and the value(s) for the name watermelon must always appear in the fifth position.

The URL will have a pound sign followed by an indefinite number of name-value pairs (up to 15). The name value pairs, connectors, and separators are encoded.  Values are strings that may be joined by "+" symbol.  Finally, Names may appear multiple times within the URL, each time with a different value.  However, since names only exactly one corresponding spot within the tracking tag string, the associated values must be joined into the same position (using "+").

Example URL:
http:www.mysite.com#currentPage=1&c%5B%5D=e%3A1119//e+apple//%3Aeq//red&c%5B%5D=e%3A1119//e+banana//%3Aeq//yellow+black&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//red&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//black

Example function using the tracking tag string created from above:
cmCreateElementTag("Tracking Parent", "Tracking Child","red-_-yellow+black-_--_--_-red+black-_--_--_--_--_--_--_--_--_--_-");

I'd like to use jquery to extract the values from the URL and place them in the right position within the tracking tag string.
0
Comment
Question by:JJ2357
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
7 Comments
 
LVL 43

Expert Comment

by:Rob
ID: 40456458
http://jsbin.com/bevivehaka/1/edit?js,console#J:L1

var myindex = {
	apple: 1,
	banana: 2,
	watermelon: 5
};
var myurl = "http://www.mysite.com#currentPage=1&c%5B%5D=e%3A1119//e+apple//%3Aeq//red&c%5B%5D=e%3A1119//e+banana//%3Aeq//yellow+black&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//red&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//black";

$(function() {
	var querystring = myurl.substring(myurl.indexOf('#')+1);
	var vars = decodeURIComponent(querystring).split('&');
	var results = {};
    for (var i = 1; i < vars.length; i++) {
        var pair = vars[i].split('=');
		var vals = pair[1].split('//');
		var fruit = vals[1].substring(2);
		var color = vals[3];
		if (results[fruit] === undefined) {
			results[fruit] = color;
		}
		else {
		  results[fruit] += "+" + color;
		}
    }
	console.dir(results);
	var tracking = Array.apply(null, new Array(15)).map(String.prototype.valueOf,"");
	$.each(results, function(i, el) {
		tracking[myindex[i]] = el;
	});
	console.log('cmCreateElementTag("Tracking Parent", "Tracking Child",'+tracking.join("-_-")+')');
});

function parseQueryString(query) {
    var vars = query.split('&');
    for (var i = 0; i < vars.length; i++) {
        var pair = vars[i].split('=');
        if (decodeURIComponent(pair[0]) == variable) {
            return decodeURIComponent(pair[1]);
        }
    }
    console.log('Query variable %s not found', variable);
}

Open in new window

0
 

Author Comment

by:JJ2357
ID: 40457112
Thanks, Rob.  Works great, with the exception of prepending "-_-" to the beginning of the string and not including double quotes around the string.  
Result:
 -_-red-_-yellow+black-_--_--_-red+black-_--_--_--_--_--_--_--_--_-

Open in new window

Expected result:
"red-_-yellow+black-_--_--_-red+black-_--_--_--_--_--_--_--_--_-"

Open in new window


Additionally, in the event that the URL contains an unencoded name-value pair, the function fails.  For example, if you append &name=value to the end, an undefined error is returned.
0
 
LVL 43

Expert Comment

by:Rob
ID: 40458565
Ok i've updated the code as the index was out by 1 (zero based array - first element is at index 0) http://jsbin.com/xukaso/1/edit?js,console#J:L1

As for the additional variables in the querystring, given that they weren't in your original spec, I haven't accounted for them.  So What are the variables that need to be parsed?  Will they always be the c[] variable or ?
0
Don't Cry: How Liquid Web is Ensuring Security

WannaCry is just the start. Read how Liquid Web is protecting itself and its customers against new threats.

 
LVL 43

Accepted Solution

by:
Rob earned 500 total points
ID: 40458587
I've modified it so that all other variables are parsed into "otherVars" object whilst the array variables are parsed into the required string (http://jsbin.com/xukaso/1/edit?js,console)

var myindex = {
	apple: 0,
	banana: 1,
	watermelon: 4
};
var myurl = "http://www.mysite.com#currentPage=1&c%5B%5D=e%3A1119//e+apple//%3Aeq//red&c%5B%5D=e%3A1119//e+banana//%3Aeq//yellow+black&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//red&c%5B%5D=e%3A1119//e+watermelon//%3Aeq//black&othervar=12345";

$(function() {
	var querystring = myurl.substring(myurl.indexOf('#')+1);
	var vars = decodeURIComponent(querystring).split('&');
	var results = {};
	var otherVars = {};
	// loop through the variables found
	for (var i = 0; i < vars.length; i++) {
		// find each pair of name/values
		var pair = vars[i].split('=');
		// we only want the "array" variables
		if (pair[0].indexOf('[]') > 0) {
			// each value is separated by //
			var vals = pair[1].split('//');
			// fruit and color found as below
			var fruit = vals[1].substring(2);
			var color = vals[3];
			// initialise the object with the color
			if (results[fruit] === undefined) {
				results[fruit] = color;
			}
			else {
				// If the fruit has already been found, add the corresponding color to the already existing value
				results[fruit] += "+" + color;
			}
		}
		else {
			// record all the other querystring variables here
			otherVars[pair[0]] = pair[1];
		}
	}
	// output the results
	console.dir(results);
	// output the other variables
	console.dir(otherVars);

	// now the cmCreateElementTag
	// create an array of 15 empty string values
	var tracking = Array.apply(null, new Array(15)).map(String.prototype.valueOf,"");
	// loop through this new array and assign the corresponding index retrieved from the myindex object
	$.each(results, function(i, el) {
		tracking[myindex[i]] = el;
	});
	// join the array as a string, serarated by -_- and output in the corresponding format
	console.log('cmCreateElementTag("Tracking Parent", "Tracking Child",'+tracking.join("-_-")+')');
});

Open in new window

0
 

Author Comment

by:JJ2357
ID: 40459478
works like a charm, tx.
0
 
LVL 43

Expert Comment

by:Rob
ID: 40459907
not a problem.  Sounds like that's solved it for you.  If so, go ahead and close the question: http://support.experts-exchange.com/customer/portal/articles/608621
0
 

Author Closing Comment

by:JJ2357
ID: 40459949
Sorry for not being clear in the original.  Thanks for the extra work.
0

Featured Post

Tutorials alone can't teach real engineering

So we built better training tools.

-Hands-on Labs
-Instructor Mentoring
-Scenario-Based Tests
-Dedicated Cloud Servers

All at your fingertips. What are you waiting for?

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction Since I wrote the original article about Handling Date and Time in PHP and MySQL several years ago, it seemed like now was a good time to update it for object-oriented PHP.  This article does that, replacing as much as possible the pr…
Introduction JSON is an acronym for JavaScript Object Notation.  It is a text-string data transport mechanism, capable of representing simple or complex data structures in a consistent and easy-to-read manner.  Similar in concept to XML, but more e…
In this fourth video of the Xpdf series, we discuss and demonstrate the PDFinfo utility, which retrieves the contents of a PDF's Info Dictionary, as well as some other information, including the page count. We show how to isolate the page count in a…
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

717 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question