With Reference of this below article i have created a sample.
http://aspsnippets.com/Articles/Paging-in-ASPNet-GridView-using-jQuery-AJAX.aspx
HTML
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
    <script src="ASPSnippets_Pager.min.js" type="text/javascript"></script>
    <style type="text/css">
        body
        {
            font-family: Arial;
            font-size: 10pt;
        }
        .Pager span
        {
            text-align: center;
            color: #999;
            display: inline-block;
            width: 20px;
            background-color: #A1DCF2;
            margin-right: 3px;
            line-height: 150%;
            border: 1px solid #3AC0F2;
        }
        .Pager a
        {
            text-align: center;
            display: inline-block;
            width: 20px;
            background-color: #3AC0F2;
            color: #fff;
            border: 1px solid #3AC0F2;
            margin-right: 3px;
            line-height: 150%;
            text-decoration: none;
        }
    </style>
    <script type="text/javascript">
        $(function () {
            //Keep the first row in the Temp div
            $('[id*=divTemp]').html(($("[id*=dlCustomers] tr").eq(0).html()));
            GetCustomers(1);
        });
        $(".Pager .page").live("click", function () {
            count = parseInt($(this).attr('page'));
            //Remove the previous rows
            if ($("[id*=dlCustomers] > tbody > tr").length >= 3) {
                for (var i = 0; i < 3; i++) {
                    $("[id*=dlCustomers] > tbody > tr").eq(i).remove();
                }
            }
            GetCustomers(parseInt($(this).attr('page')));
        });
        function GetCustomers(pageIndex) {
            $.ajax({
                type: "POST",
                url: "Default.aspx/GetCustomers",
                data: '{pageIndex: ' + pageIndex + '}',
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: OnSuccess,
                failure: function (response) {
                    alert(response.d);
                },
                error: function (response) {
                    alert(response.d);
                }
            });
        }
        function OnSuccess(response) {
            var xmlDoc = $.parseXML(response.d);
            var xml = $(xmlDoc);
            var row;
            var customers = xml.find("Customers");
            var repeatColumns = parseInt("<%=dlCustomers.RepeatColumns == 0 ? 1 : dlCustomers.RepeatColumns %>");
            var rowCount = Math.ceil(customers.length / repeatColumns);
            var i = 0;
            while (i < repeatColumns * rowCount) {
                //If the Row is less then 3 then use divTemp html to get the Row with 3 tables
                if (rowCount < 3) {
                    $("[id*=dlCustomers]").append('<tbody><tr>' + $('[id*=divTemp]').html() + '</tr></tbody>');
                    row = $("[id*=dlCustomers] > tbody > tr:last").clone(true);
                    $("[id*=dlCustomers] > tbody > tr:last").css('display', 'none');
                }
                else {
                    $("[id*=dlCustomers] > tbody > tr:last").css('display', 'block');
                    row = $("[id*=dlCustomers] > tbody > tr:last").clone(true);
                }
                for (var j = 0; j < repeatColumns; j++) {
                    var customer = $(customers[i]);
                    if (customer.length == 0) {
                        $("table:last", row).remove();
                    } else {
                        $(".name", row).eq(j).html(customer.find("ContactName").text());
                        $(".city", row).eq(j).html(customer.find("City").text());
                        $(".postal", row).eq(j).html(customer.find("PostalCode").text());
                        $(".country", row).eq(j).html(customer.find("Country").text());
                        $(".phone", row).eq(j).html(customer.find("Phone").text());
                        $(".fax", row).eq(j).html(customer.find("Fax").text());
                    }
                    i++;
                }
                $("[id*=dlCustomers]").append(row);
            }
            $("[id*=dlCustomers] tr").eq(0).remove();
            $("[id*=dlCustomers]").show();
            var pager = xml.find("Pager");
            $(".Pager").ASPSnippets_Pager({
                ActiveCssClass: "current",
                PagerCssClass: "pager",
                PageIndex: parseInt(pager.find("PageIndex").text()),
                PageSize: parseInt(pager.find("PageSize").text()),
                RecordCount: parseInt(pager.find("RecordCount").text())
            });
            //Hide the empty Row
            if ($("[id*=dlCustomers] > tbody > tr").length == 4) {
                $("[id*=dlCustomers] > tbody > tr").eq(3).css('display', 'none');
            }
        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:DataList ID="dlCustomers" runat="server" RepeatLayout="Table" RepeatColumns="3"
            CellPadding="2" CellSpacing="2">
            <ItemTemplate>
                <table cellpadding="2" cellspacing="0" border="1" class="innerTable" style="width: 200px;
                    height: 100px; border: dashed 2px #04AFEF; background-color: #B0E2F5">
                    <tr>
                        <td>
                            <b><u><span class="name">
                                <%# Eval("ContactName") %></span></u></b>
                        </td>
                    </tr>
                    <tr>
                        <td>
                            <b>City: </b><span class="city">
                                <%# Eval("City") %></span><br />
                            <b>Postal Code: </b><span class="postal">
                                <%# Eval("PostalCode") %></span><br />
                            <b>Country: </b><span class="country">
                                <%# Eval("Country")%></span><br />
                            <b>Phone: </b><span class="phone">
                                <%# Eval("Phone")%></span><br />
                            <b>Fax: </b><span class="fax">
                                <%# Eval("Fax")%></span><br />
                        </td>
                    </tr>
                </table>
            </ItemTemplate>
        </asp:DataList>
        <div id="divTemp" style="display: none;">
        </div>
        <div class="Pager">
        </div>
    </div>
    </form>
</body>
</html>
Namespace
using System.Data.SqlClient;
using System.Web.Services;
using System.Configuration;
using System.Data;
C#
Set the Page size as 9 to show the 3 Item in the DataList.
private static int PageSize = 9;
protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        this.BindDummyItem();            
    }
}
private void BindDummyItem()
{
    DataTable dummy = new DataTable();
    dummy.Columns.Add("CustomerID");
    dummy.Columns.Add("ContactName");
    dummy.Columns.Add("Country");
    dummy.Columns.Add("City");
    dummy.Columns.Add("PostalCode");
    dummy.Columns.Add("Phone");
    dummy.Columns.Add("Fax");
    int count = dlCustomers.RepeatColumns == 0 ? 1 : dlCustomers.RepeatColumns;
    for (int i = 0; i < count; i++)
    {
        dummy.Rows.Add();
    }
    dlCustomers.DataSource = dummy;
    dlCustomers.DataBind();
}
[WebMethod]
public static string GetCustomers(int pageIndex)
{
    string query = "[GetCustomers_Pager]";
    SqlCommand cmd = new SqlCommand(query);
    cmd.CommandType = CommandType.StoredProcedure;
    cmd.Parameters.AddWithValue("@PageIndex", pageIndex);
    cmd.Parameters.AddWithValue("@PageSize", PageSize);
    cmd.Parameters.Add("@RecordCount", SqlDbType.Int, 4).Direction = ParameterDirection.Output;
    return GetData(cmd, pageIndex).GetXml();
}
private static DataSet GetData(SqlCommand cmd, int pageIndex)
{
    string strConnString = ConfigurationManager.ConnectionStrings["conString"].ConnectionString;
    using (SqlConnection con = new SqlConnection(strConnString))
    {
        using (SqlDataAdapter sda = new SqlDataAdapter())
        {
            cmd.Connection = con;
            sda.SelectCommand = cmd;
            using (DataSet ds = new DataSet())
            {
                sda.Fill(ds, "Customers");
                DataTable dt = new DataTable("Pager");
                dt.Columns.Add("PageIndex");
                dt.Columns.Add("PageSize");
                dt.Columns.Add("RecordCount");
                dt.Rows.Add();
                dt.Rows[0]["PageIndex"] = pageIndex;
                dt.Rows[0]["PageSize"] = PageSize;
                dt.Rows[0]["RecordCount"] = cmd.Parameters["@RecordCount"].Value;
                ds.Tables.Add(dt);
                return ds;
            }
        }
    }
}
SQL
I have used the Northwind Databse
Install the Northwind and Pubs Sample Databases in SQL Server Express
StoredProcedure
 
-- [dbo].[GetCustomers_Pager] 10, 9 , null
CREATE PROCEDURE [dbo].[GetCustomers_Pager]
      @PageIndex INT = 1
      ,@PageSize INT = 9
      ,@RecordCount INT OUTPUT
AS
BEGIN
      SET NOCOUNT ON;
      SELECT ROW_NUMBER() OVER
      (
            ORDER BY [CustomerID] ASC
      )AS RowNumber
      ,[CustomerID]
	  ,[ContactName]
      ,[CompanyName]
	  ,[Country]
	  ,[City]
      ,[PostalCode]
      ,[Phone]
	  ,[Fax]
      INTO #Results
      FROM [Customers]
     
      SELECT @RecordCount = COUNT(*)
      FROM #Results
           
      SELECT * FROM #Results
      WHERE RowNumber BETWEEN(@PageIndex -1) * @PageSize + 1 AND(((@PageIndex -1) * @PageSize + 1) + @PageSize) - 1
     
      DROP TABLE #Results
END
Screenshot
