jQuery

jQuery empty Selector Examples

Ever wondered how to use the jQuery empty selector? In this article, I am going to share different ways of using the empty selector in jQuery along with easy to follow examples. Read on to find out more.

How to use jQuery empty selector

Let’s assume that we have different html elements on the web page. such as Table. What essentially the :empty selector does is that it select all elements that have no children (including text nodes). So let’s see how to use :empty:

Example 1: Use :empty on Table to alert /get all empty cells of the table

<style type="text/css">
table td {
	border: 1px solid #CCC;	
}
.cell_class {
	background-color: #D0F5FF;
	border: 1px solid #06F;
}
</style>

<table width="50%" border="1" cellspacing="1" cellpadding="1" id="table1">
  <tr>
    <td>R1C1</td>
    <td></td>
    <td>R1C3</td>
  </tr>
  <tr>
    <td></td>
    <td>R2C2</td>
    <td></td>
  </tr>
  <tr>
    <td></td>
    <td></td>
    <td>R3C3</td>
  </tr>
</table>

<p>
<input type="submit" name="sbt_get_all_empty_cells" id="sbt_get_all_empty_cells" value="Get all Empty Cells of Table">
</p>

	$('#sbt_get_all_empty_cells').on("click", function(e){	

		$('#table1 td:empty').each(function(index) {

			var row_index = $(this).parent().index('tr');

			var col_index = $(this).index('tr:eq('+row_index+') td');

			alert('Row Number # '+(row_index + 1)+' Column Number # '+(col_index + 1) + ' is Empty!');

		});	

		e.preventDefault();

	});

When you run the above code, simply click the “Get all Empty Cells of Table” button and that will alert all the empty cell Row & Column numbers. You can apply whatever manipulations you want by using them.

Example 2: Use :empty on Table to Write Custom Data To Empty Cells

There are different parts in this example, so let’s take a look at each of these parts separately. The following is the common HTML source for all these parts.

<style type="text/css">
table td {
	border: 1px solid #CCC;	
}
.cell_class {
	background-color: #D0F5FF;
	border: 1px solid #06F;
}
</style>

<table width="50%" border="1" cellspacing="1" cellpadding="1" id="table2">
  <tr>
    <td>R1C1</td>
    <td></td>
    <td>R1C3</td>
  </tr>
  <tr>
    <td></td>
    <td>R2C2</td>
    <td></td>
  </tr>
  <tr>
    <td></td>
    <td></td>
    <td>R3C3</td>
  </tr>
</table>

<p>
<input type="submit" name="sbt_write_to_empty_cells" id="sbt_write_to_empty_cells" value="Write to all Empty Cells of Table 2">

<input type="submit" name="sbt_revert_to_empty_cells" id="sbt_revert_to_empty_cells" value="Revert To Empty Cells of Table 2">
</p>

<p>
<input type="submit" name="sbt_add_class_to_empty_cells" id="sbt_add_class_to_empty_cells" value="Add Class To Empty Cells of Table 2">

<input type="submit" name="sbt_remove_class_from_empty_cells" id="sbt_remove_class_from_empty_cells" value="Remove Class From Empty Cells of Table 2"></p>

Part 1:  Write to all Empty Cells of the Table

	$('#sbt_write_to_empty_cells').on("click", function(e){	

		$('#table2 td:empty').text("Cell is Empty!");

		e.preventDefault();

	});

When you click the button, all empty cells of the table will be filled with the custom text (Cell is Empty!).

Part 2:  Revert all / Make Table Cells by removing the custom text that you filled them with

	$('#sbt_revert_to_empty_cells').on("click", function(e){	

		$('#table2 td').each(function(index) {

			if( 'Cell is Empty!' == $(this).text() )
			{
				$(this).text('');
			}			

		});				

		e.preventDefault();

	});

Part 3:  Add Custom Class to the Empty Cells of the Table

	$('#sbt_add_class_to_empty_cells').on("click", function(e){	

		$('#table2 td:empty').addClass('cell_class');

		e.preventDefault();

	});

Add a class or multiple class of your choice to empty table cells by clicking the button.

Part 4:  Remove Custom Class that you applied to the Empty Cells of the Table

	$('#sbt_remove_class_from_empty_cells').on("click", function(e){	

		$('#table2 td:empty').removeClass('cell_class');

		e.preventDefault();

	});

Click on the button to remove the class that you applied to the empty table cells.

That’s it!

Do you know of any other ways to use jQuery empty selector? Feel free to suggest by commenting below.

Share your thoughts, comment below now!

*

*