How is something like this done?

http://shop.nhl.com/product/index.jsp?productId=3797003&cp=4055930&clickid=body_bestsell_img

There is this function to customize a jersey. After you select a size, you can type in your last name into an input field and the image immediately displays the typed name on the back of the jersey. How is something like this done?
I’d like to be able to have people be able to customize a product on my website with a similar function.
any help would be much appreciated