How to Use CDATA in XML?
All text in an XML document will be parsed by the parser.
But text inside a CDATA section will be ignored by the parser.
XML parsers normally parse all the text in an XML document.
When an XML element is parsed, the text between the XML tags is also parsed:
Characters like "<" and "&" are illegal in XML elements.
"<" will generate an error because the parser interprets it as the start of a new element.
"&" will generate an error because the parser interprets it as the start of an character entity.
Some text, like JavaScript code, contains a lot of "<" or "&" characters. To avoid errors script code can be defined as CDATA.
Everything inside a CDATA section is ignored by the parser.
A CDATA section starts with "<![CDATA[" and ends with "]]>":
Code:
A CDATA section cannot contain the string "]]>". Nested CDATA sections are not allowed.
The "]]>" that marks the end of the CDATA section cannot contain spaces or line breaks.
Reference: W3Schools, StackOverflow
XML parsers normally parse all the text in an XML document.
When an XML element is parsed, the text between the XML tags is also parsed:
<message>This text is also parsed</message>The parser does this because XML elements can contain other elements, as in this example, where the <name> element contains two other elements (first and last):
<name><first>Bill</first><last>Gates</last></name>and the parser will break it up into sub-elements like this:
<name>Parsed Character Data (PCDATA) is a term used about text data that will be parsed by the XML parser.
<first>Bill</first>
<last>Gates</last>
</name>
CDATA - (Unparsed) Character Data
The term CDATA is used about text data that should not be parsed by the XML parser.Characters like "<" and "&" are illegal in XML elements.
"<" will generate an error because the parser interprets it as the start of a new element.
"&" will generate an error because the parser interprets it as the start of an character entity.
Some text, like JavaScript code, contains a lot of "<" or "&" characters. To avoid errors script code can be defined as CDATA.
Everything inside a CDATA section is ignored by the parser.
A CDATA section starts with "<![CDATA[" and ends with "]]>":
<script>In the example above, everything inside the CDATA section is ignored by the parser.
<![CDATA[
function matchwo(a,b)
{
if (a < b && a < 0) then
{
return 1;
}
else
{
return 0;
}
}
]]>
</script>
Code:
- string CDATAStart = "<![CDATA[", CDATAEnd = "]]>";
- LongDescription = CDATAStart + mcLongDescription.Trim() + CDATAEnd;
A CDATA section cannot contain the string "]]>". Nested CDATA sections are not allowed.
The "]]>" that marks the end of the CDATA section cannot contain spaces or line breaks.
Reference: W3Schools, StackOverflow
C# Code to implement Google Analytics Tracking Script dynamically
In general we track a page using JavaScript statically. This C# code is used to implement Google Analytics Tracking Script dynamically for every page we want to do it.
Another way: Click here.
Source Code:
- using System;
- using System.Collections.Generic;
- using System.Configuration;
- using System.Linq;
- using System.Web;
- namespace KPMGAudit.Web.GoogleAnalytics
- {
- public static class Tracking
- {
- public static string TrackingScript(string url)
- {
- var jsTestString = string.Format(@"
- <script type=""text/javascript"">
- var _gaq = _gaq || [];
- _gaq.push(['_setAccount', '{0}']);
- _gaq.push(['_trackPageview','{1}']);
- (function() {{
- var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
- ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
- var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
- }})();
- </script>", ConfigurationManager.AppSettings["GoogleAnalyticsAccountCode"], url);
- return jsTestString;
- }
- }
- }
- // Inject javascript into Long Description
- var url = string.Format("/{0}/{1}", mcContentCategory.AsUrl(), mcTitle.AsUrl());
- mcLongDescription = mcLongDescription + GoogleAnalytics.Tracking.TrackingScript(url);
Another way: Click here.
How to remove the trailing directory slash from the URL?
It's possible to configure Umbraco to remove the final trailing
slash on the URL. If you want to do this, locate the
'umbracoSettings.config' file. This can be found in the
'webroot\config\' directory of your site.
Open this file and locate the 'addTrailingSlash' setting in the 'requestHandler' section of the file.
Open this file and locate the 'addTrailingSlash' setting in the 'requestHandler' section of the file.
<requestHandler>Then all you need to do is to change the addTrailingSlash value to 'false'. Don't forget to save your changes.
<addTrailingSlash>false</addTrailingSlash>
</requestHandler>
Wednesday, 6 August 2014
Posted by Jebastin
How to remove the .ASPX extension from the URL?
First of all, to configure Umbraco to show URL's without the .aspx
extension, you're going to need to locate the 'umbracoUseDirectoryUrls'
setting in the ' appSettings' section of the 'web.config' file for your
site.
<appSettings>Once you've opened this file, all you need to do is change the 'umbracoUseDirectoryUrls' value to 'true'.
<add key="umbracoUseDirectoryUrls" value="true" />
</appSettings>
How to load AddThis dynamically with ajax?
On page load there is no issues with AddThis widget. But when the 'Share' button is binding via ajax, then the AddThis functionality will not work. To fix this solution, use the following script.
<script type="text/javascript">
function generateAddThisButton(ID,URL,Title,Description) {
var addthis_ui_config =
{
services_compact: 'facebook, myspace, igoogle, netvibes, windows, dashboard, more'
}
var host = window.location.host;
var propertyURL = host + URL;
var propertyTitle = Title;
var propertyDescription = Description.replace('<p>','').replace('</p>','');
var addthis_share_config =
{
url: propertyURL,
title: propertyTitle,
description: propertyDescription
//swfurl: "http://www.youtube.com/v/1F7DKyFt5pY&hl=en&fs=1",
//screenshot: "http://i2.ytimg.com/vi/1F7DKyFt5pY/default.jpg"
}
addthis.button("#" + ID, addthis_ui_config, addthis_share_config);
}
</script>
How to Add Active Navigation Class Based on URL?
Ideally you output this class from the server side, but if you can't...
Let's say you have navigation like this:
HTML:
And you are at the URL:
http://yoursite.com/about/team/
And you want the About link to get a class of "active" so you can visually indicate it's the active navigation.
jQuery:
JavaScript:
Essentially that will match links in the nav who's href attribute begins with "/about" (or whatever the secondary directory happens to be).
Comparison Operators:
Reference: CSS-Tricks
Let's say you have navigation like this:
HTML:
- <nav>
- <ul>
- <li><a href="/">Home</a></li>
- <li><a href="/about/">About</a></li>
- <li><a href="/clients/">Clients</a></li>
- <li><a href="/contact/">Contact Us</a></li>
- </ul>
- </nav>
And you are at the URL:
http://yoursite.com/about/team/
And you want the About link to get a class of "active" so you can visually indicate it's the active navigation.
jQuery:
- <script type="text/javascript">
- $(function () {
- var page = location.pathname.split("/")[1];
- if (page != "") {
- $('nav a[href^="/' + page + '"]').parent().addClass('active');
- }
- });
- </script>
JavaScript:
- <script type="text/javascript">
- (function() {
- var nav = document.getElementById('nav'),
- anchor = nav.getElementsByTagName('a'),
- current = window.location.pathname.split('/')[1];
- for (var i = 0; i < anchor.length; i++) {
- if(anchor[i].href == current) {
- anchor[i].className = "active";
- }
- }
- })();
- </script>
Essentially that will match links in the nav who's href attribute begins with "/about" (or whatever the secondary directory happens to be).
Comparison Operators:
- = is equal
- != is not equal
- ^= starts with
- $= ends with
- *= contains
Reference: CSS-Tricks
How to enable paste option in Windows Server 2008 to copy from local machine?
Restart rdpclip.exe in Server machine.