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
312 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
  • 4
  • 3
7 Comments
 
LVL 42

Expert Comment

by:Rob Jurd, EE MVE
Comment Utility
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
Comment Utility
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 42

Expert Comment

by:Rob Jurd, EE MVE
Comment Utility
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
How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

 
LVL 42

Accepted Solution

by:
Rob Jurd, EE MVE earned 500 total points
Comment Utility
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
Comment Utility
works like a charm, tx.
0
 
LVL 42

Expert Comment

by:Rob Jurd, EE MVE
Comment Utility
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
Comment Utility
Sorry for not being clear in the original.  Thanks for the extra work.
0

Featured Post

Why You Should Analyze Threat Actor TTPs

After years of analyzing threat actor behavior, it’s become clear that at any given time there are specific tactics, techniques, and procedures (TTPs) that are particularly prevalent. By analyzing and understanding these TTPs, you can dramatically enhance your security program.

Join & Write a Comment

Suggested Solutions

I found this questions asking how to do this in many different forums, so I will describe here how to implement a solution using PHP and AJAX. The logical flow for the problem should be: Write an event handler for the first drop down box to get …
SASS allows you to treat your CSS code in a more OOP way. Let's have a look on how you can structure your code in order for it to be easily maintained and reused.
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)
In this fifth video of the Xpdf series, we discuss and demonstrate the PDFdetach utility, which is able to list and, more importantly, extract attachments that are embedded in PDF files. It does this via a command line interface, making it suitable …

744 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

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now