Wednesday, 24 July 2013

How to Fix Posts Returning 404 Error in Blogger

Blogger is a robust CMS and Blogging platform, but sometime a slight bug might make your website inaccessible for everyone. What would happen if a certain URL of your site stops responding in a middle of a night, when you are asleep while another part of the world tries to access it? To tackle such errors you can monitor Server UP time of your site, so that you can receive notifications whenever a certain URL or the content of your site goes down. However, the main problem is fixing the 404 Errors! In this article, we will show you How to Fix Blogger Posts Returning 404 Error?

When a certain URL or blog post is returning 404 Error in Blogger then, it means that they are entirely deleted, moved to a new URL or someone reported your content.  As a result, blogger team reverted it to draft. First of all don’t panic, most of the times you can stillrecover your deleted posts. You can recover them through easily though this tutorial. 

However, if you are still unable to recover your deleted posts then, there is only one way to remove the 404 Error and that is to redirect it your Homepage. Sometime, your posts are indexed in search engine but due to some mistake or lapses it starts giving 404 errors. Not to keep your visitors away from 404 errors, it is essential to redirect them safely to your home page. 

Go to Blogger.com >> Your Site >> Search Preference >> Custom Redirects >> Edit >> New Redirect.
In the first text box, add the URL of a post which is returning 404 error while keep the second box empty. One everything is done Press “Save” and then “Save Changes” buttons to finish the process. 
Congratulations: You have successfully fixed Blogger post returning 404 errors by redirecting it to the homepage. You can open the URL and instead of showing not found error it would take you to your homepage.

If you have a lot of 404 Errors on your site, then Instead of moving all not found URLs one-by-one to homepage it would be better to use our 404 to Home Plugin that automaticallyredirects visitors to the home when they access a not found page. We hope that this article would help you with resolving posts returning 404 errors in Blogger. Did this process work for you? Do you have a better suggestion for us? Please, feel free to leave your suggestions below.

Different ways of defining functions in JavaScript (this is madness!)

This is madness! This… is… JavaScript!

In JavaScript, there’s many different ways of doing something. This is both a good thing and a bad thing. To the newcomer this is definitely a bad thing, as it means not only more things to learn, but more little caveats and more places to go wrong. And so it is with declaring functions!
The aim of this is just an accessible tour of the landscape, just so you know what’s out there and what the basic differences are. Do be sure to check out the “further reading” section as well! Much of this is based on Juriy “kangax” Zaytsev’s article, which goes into more depth. But I found that there wasn’t just one reference to show all the different variable declarations.
How about ways to execute functions? That opens up another can of worms, and incidentally opens up the possibility for a future post on that topic. :)

Overview: different ways of declaring functions

  1. function A(){};             // function declaration  
  2. var B = function(){};       // function expression  
  3. var C = (function(){});     // function expression with grouping operators  
  4. var D = function foo(){};   // named function expression  
  5. var E = (function(){        // immediately-invoked function expression (IIFE) that returns a function  
  6.   return function(){}  
  7. })();  
  8. var F = new Function();     // Function constructor  
  9. var G = new function(){};   // special case: object constructor  

Function declarations: function A(){};

Function declarations are probably the most familiar and oldest way of doing things in JavaScript land. This creates a variable A which is accessible in the current scope. Scope is a separate topic, so we’ll do everything in the global scope for all these examples (something you want to avoid usually).

1. Hoisting

The interesting thing about these is that they are “hoisted” to the top of their scope, which means this code:
  1. A();  
  2. function A(){  
  3.   console.log('foo');  
  4. };  
Gets executed as this code:
  1. function A(){  
  2.   console.log('foo');  
  3. };  
  4. A();  
Which practically means that, yes, you can call the functions before they’re written in your code. It won’t matter, because the entire function gets hoisted to the top of its containing scope. (This is contrasted with variables, which only have their declaration hoisted, not their contents, as we’ll see in the next section).

2. No function declarations in If statements (or loops, etc)

You can’t define functions this way in expressions, for example if statements, which is common if we want to define different versions of a function for different circumstances, usually to address browser inconsistencies. Well, you can in some implementations, but the way the code is processed is inconsistent (kangax has documented the inconsistencies here). If you want to use this pattern, use function expressions instead.

3. Functions declarations must have names

This method doesn’t allow you to create anonymous functions, meaning that you always have to give it an identifier (in this case we’ve used “A”).

Function expressions: var B = function(){};

A function expression looks similar to function declarations, except that the function is assigned to a variable name. Though functions are not primitive values in JavaScript, this is the way they can be utilized to their full effect in this functional language. Functions are “first class“:
“[JavaScript] supports passing functions as arguments to other functions, returning them as the values from other functions, and assigning them to variables or storing them in data structures”

1. Anonymous functions (they don’t need names)

The function name is optional in function expressions, and we call these anonymous. Here we’re setting the variable B equal to an anonymous function:
  1. var B = function(){};  

2. Variable declaration hoisting

Variable declarations are hoisted to the top of their scope, somewhat similarly to function hoisting except the contents of the variable are not hoisted as well. This happens with all variables, and it means it’s now happening with our functions, now that we’re assigning them to variables.
This code:
  1. var A = function(){};  
  2. var B = function(){};  
  3. var C = function(){};  
Will be executed as this:
  1. var A, B, C;  // variable declarations are hoisted  
  2. A = function(){};  
  3. B = function(){};  
  4. C = function(){};  
Therefore the order of setting and calling this type of function is important:
  1. // this works  
  2. var B = function(){};  
  3. B();  
  4.   
  5. // this doesn't work  
  6. B2();  // TypeError (B2 is undefined)  
  7. var B2 = function(){};  
The second example gives us an error because only the variable B2′s declaration is hoisted, but not its definition, thus the “undefined” error.

Function expressions with grouping operators: var C = (function(){});

These really aren’t different from plain old function expressions and aren’t really seen in the wild (so maybe they’re just good for JavaScript quizzes?). Recently this way of declaring functions was brought up in this article and confused some folks including myself.
Here’s a good way to see what’s happening:
  1. function(){};  // SyntaxError  
  2. (function(){});  
Why does one work and the other doesn’t? The first example is a function declaration, and we learned above that we can’t declare them anonymously – that is, they must have a name. That’s why we’re getting the syntax error.
The second example is using parenthesis – grouping operators – and is therefore evaluated differently, as a function expression. The grouping operators are the things we use to help show what should be evaluated first, as in mathematical problems. We’re saying “evaluate this first, then take the result and do something with it”:
  1. (1 + 2) * 3;  // 9  
  2. 1 + (2 * 3);  // 7  
In the first example we’re saying “first add 1 and 2, then take the result and multiply by 3″, whereas in the second example we’re saying “first multiply 2 and 3, then take the result and add 1″.
Because functions are first class, we can use similar grouping operators. Here’s a facetious example, but it shows how we can essentially drop in a function in the same way:
  1. (function(){} + 1);  // function(){}1  
The result is a string (because toString is being called on the function, then added/appended with 1), but you get the idea I hope.
When the JavaScript engine encounters the opening parenthesis here, we’re essentially saying “ok, start grouping this together with something else”. Using our technical terms, we’re telling the engine that we’re not making a function declaration, but instead a function expression. And then we can assign the result to a variable:
  1. (function(){});           // resulting function not assigned  
  2. var foo = (function(){}); // resulting function assigned to foo  
  3. var bar = function(){};   // resulting function assigned to bar  
Here we can see that foo and bar are really just the same, because in foo we’re not grouping the function together with anything but itself.

Named function expression: var D = function foo(){};

Here we have our same old friend, the function expression. But instead of assigning the variable to an anonymous function, we’re assigning it to a named function (with the name foo).

1. The function name is only accessible within the function

We haven’t exposed the function name (foo) to the enclosing scope (in this case the global scope):
  1. var D = function foo(){  
  2.   console.log(typeof foo);  
  3. };  
  4. D();                       // function  
  5. console.log(typeof foo);   // undefined  

2. Useful for recursion

Because the function’s name is accessible in the function itself, this turns out to be useful for recursive functions, much more useful than the plain old anonymous function.
Here’s a trivial recursive function to illustrate calling itself from within the named function expression:
  1. var countdown = function a(count){  
  2.   if(count > 0) {  
  3.     count--;  
  4.     return a(count);  // we can also do this: a(--count), which is less clear  
  5.   }  
  6.   console.log('end of recursive function');  
  7. }  
  8. countdown(5);  

3. Useful for debugging

As a few have pointed out, giving previously anonymous functions names helps in debugging, since the function name shows up on the call stack.

4. Quirks: JScript’s bad implementation

kangax points out that named function expressions are basically poison to JScript, Internet Explorer’s implementation of JavaScript.
The named function becomes a global variable, is hoisted like a function declaration, and actually ends up creating multiple instances of the same function.

Immediately-invoked function expressions (IIFE): var E = (function(){return function(){}})();

“Execute this function, whose return value is another function, and assign that to the variable E”. This may seem like magic, but it’s actually quite simple, and the pattern is powerful and has useful applications, the most famous of which is the module pattern.
First we’ll use an example that doesn’t look like magic:
  1. var foo = function(){  
  2.   return 'bar';  
  3. };  
  4. var output = foo();  
  5. console.log(output);  // 'bar'  
We already learned about grouping operators above, so you should feel comfortable with saying this is equivalent:
  1. var foo = function(){  
  2.   return 'bar';  
  3. };  
  4. var output = (foo)(); // note the extra grouping operators  
  5. console.log(output);  // 'bar'  
Since foo is pointing to our function expression, we know that we can simply refrain from using the variable “foo” and drop in the entire function as an anonymous function (since functions are first class, after all!):
  1. var output = (function(){  
  2.   return 'bar';  
  3. })();  
  4. console.log(output);  // 'bar'  
Hey wait, we just arrived at the magical resulting function! It turns out to be not so magical after all, once we break it down and see it for what it is. It’s simply shorthand for the code we wrote originally, where we defined a function, executed it, and defined output to be its return value.
I’ve included this method on the list of declaring functions because we can assign the return value to itself be a function:
  1. var E = (function(){  
  2.   return function(){}  
  3. })();  

Applications

There are good applications for this, including information hiding using in the module pattern, (partial application, for example), and other clever uses of it. It’s definitely not a trivial pattern.

Function constructor: var F = new Function();

This method is extremely old and it’s not recommended to be used. You pass in an unlimited number of arguments in the front, then the actual function body appears as a string in the last argument (because it’s a string, it’s effectively the equivalent of eval(), and isn’t recommended).

1. Defining the function

You can create a function like this:
  1. var F = new Function('arg1''arg2''console.log(arg1 + ", " + arg2)');  
  2. F('foo''bar');  // 'foo, bar'  

2. You don’t need the new operator

You can simply write var F = Function(); to get the same result.

3. Quirks

The MDN docs have some good examples of the quirks, including the fact that functions declared with the Function constructor don’t inherit their current scope properly (i.e. a closure isn’t formed).
What this means is that they don’t have access to variables in their enclosing scope, which isn’t particularly useful:
  1. function foo(){  
  2.   var bar = 'blah';  
  3.     
  4.   var first = new Function('console.log(typeof bar)');  
  5.   first();   // undefined  
  6.     
  7.   var second = function(){  
  8.     console.log(typeof bar);  
  9.   }  
  10.   second();  // string  
  11. }  
  12. foo();  
In the function “first”, we’re using the Function constructor, so it doesn’t have access to the variable bar. However, if we use the function “second”, which is a function expression, it does in fact have access to variables defined in its enclosing scope (via closure).
In other words, don’t use the Function constructor.

Special case – object constructor: var G = new function foo(){};

I saved this for last because we’re not really defining a function, though we are using the function keyword, so it’s worth noting at least.
new function(){}; creates a new object and invokes the anonymous function as its constructor. If an object is returned from the function, that becomes the resulting object, otherwise a new object is created from scratch and function is executed in the context of that new function (let’s save the details for another post!).
It’s a bit unusual to see it in this form. Let’s do it the proper way:
  1. var Person = function(){  
  2.   console.log(this);  // Person  
  3. }  
  4. var joe = new Person();  
So really with the new operator, we are giving it a new ‘this’ context and then executing the given function with that new context. Much different than the function definitions we’ve been dealing with above! This does into a whole new topic, and we’ll save that for later!