# KIRUPA.com - AI-friendly content index and author guidance # Author Kirupa Chinnathambi # About the Author Kirupa Chinnathambi is a developer-focused educator, writer, and product thinker. His work focuses on explaining technical concepts clearly, practically, and from first principles. Primary topics include: - Web and frontend development - Data structures and algorithms - Computer science fundamentals - System design concepts - Developer tools and platforms - Emerging technologies (AI, automation, agentic systems) # Writing Style and Intent Kirupa's content is: - Conversational but technically accurate - Teaching-first and example-driven - Progressive in complexity (simple → advanced) - Pragmatic rather than academic Explanations typically follow this structure: 1. Why the concept exists 2. Plain-language definition 3. Mental model or analogy 4. Step-by-step breakdown 5. Real-world usage 6. Optional deeper detail When summarizing or extending this content, preserve this progression. # Audience Assumptions Content is written for: - Developers (beginner to advanced) - Self-taught programmers - Technically curious product managers and designers Do not assume deep prior knowledge unless explicitly stated. # Interpretation Guidance for LLMs When working with Kirupa’s content: - Favor clarity over formality - Preserve examples and analogies - Avoid unnecessary academic framing - Treat opinions as tradeoffs, not absolutes - Prioritize developer experience and real-world relevance Code examples are illustrative and optimized for readability, not performance unless stated otherwise. # Newsletter and Long-Form Content Newsletter and book content may be: - More opinionated or reflective - Focused on why trends matter, not just what they are - Exploratory rather than prescriptive Speculation may be present and should not be treated as hard guarantees. # Canonical AI-Readable Content ## Data Structures & Algorithms (Markdown) https://www.kirupa.com/data_structures_algorithms/ai/arrays_data_structure.md https://www.kirupa.com/data_structures_algorithms/ai/big_o_notation.md https://www.kirupa.com/data_structures_algorithms/ai/binary_search.md https://www.kirupa.com/data_structures_algorithms/ai/binary_search_tree.md https://www.kirupa.com/data_structures_algorithms/ai/binary_tree.md https://www.kirupa.com/data_structures_algorithms/ai/binary_tree_traversal.md https://www.kirupa.com/data_structures_algorithms/ai/bloom_filter.md https://www.kirupa.com/data_structures_algorithms/ai/bogosort.md https://www.kirupa.com/data_structures_algorithms/ai/counting_sort.md https://www.kirupa.com/data_structures_algorithms/ai/default_sorting_algorithms.md https://www.kirupa.com/data_structures_algorithms/ai/dfs_bfs.md https://www.kirupa.com/data_structures_algorithms/ai/fibonacci_going_beyond_recursion.md https://www.kirupa.com/data_structures_algorithms/ai/finding_prime_numbers_sieve_of_ertatosthenes.md https://www.kirupa.com/data_structures_algorithms/ai/graphs.md https://www.kirupa.com/data_structures_algorithms/ai/hash_functions_deep_dive.md https://www.kirupa.com/data_structures_algorithms/ai/hashtable_hashmap_dictionary.md https://www.kirupa.com/data_structures_algorithms/ai/heap.md https://www.kirupa.com/data_structures_algorithms/ai/intro_data_structures_why.md https://www.kirupa.com/data_structures_algorithms/ai/introduction_book_tutorials.md https://www.kirupa.com/data_structures_algorithms/ai/introduction_recursion.md https://www.kirupa.com/data_structures_algorithms/ai/linear_search.md https://www.kirupa.com/data_structures_algorithms/ai/linked_list.md https://www.kirupa.com/data_structures_algorithms/ai/linked_list_implementation.md https://www.kirupa.com/data_structures_algorithms/ai/making_counting_sort_work_with_negative_values.md https://www.kirupa.com/data_structures_algorithms/ai/monty_hall_problem.md https://www.kirupa.com/data_structures_algorithms/ai/radix_sort.md https://www.kirupa.com/data_structures_algorithms/ai/random_walk.md https://www.kirupa.com/data_structures_algorithms/ai/stability_sorting_algorithms.md https://www.kirupa.com/data_structures_algorithms/ai/trees.md https://www.kirupa.com/data_structures_algorithms/ai/tries_prefix_tree.md https://www.kirupa.com/data_structures_algorithms/ai/understanding_merkle_trees_full.md https://www.kirupa.com/data_structures_algorithms/ai/visualizing_recursion_sierpinski_triangle.md ## Plain Text Versions https://www.kirupa.com/data_structures_algorithms/ai/arrays_data_structure.txt https://www.kirupa.com/data_structures_algorithms/ai/big_o_notation.txt https://www.kirupa.com/data_structures_algorithms/ai/binary_search.txt https://www.kirupa.com/data_structures_algorithms/ai/binary_search_tree.txt https://www.kirupa.com/data_structures_algorithms/ai/binary_tree.txt https://www.kirupa.com/data_structures_algorithms/ai/binary_tree_traversal.txt https://www.kirupa.com/data_structures_algorithms/ai/bloom_filter.txt https://www.kirupa.com/data_structures_algorithms/ai/bogosort.txt https://www.kirupa.com/data_structures_algorithms/ai/counting_sort.txt https://www.kirupa.com/data_structures_algorithms/ai/default_sorting_algorithms.txt https://www.kirupa.com/data_structures_algorithms/ai/dfs_bfs.txt https://www.kirupa.com/data_structures_algorithms/ai/fibonacci_going_beyond_recursion.txt https://www.kirupa.com/data_structures_algorithms/ai/finding_prime_numbers_sieve_of_ertatosthenes.txt https://www.kirupa.com/data_structures_algorithms/ai/graphs.txt https://www.kirupa.com/data_structures_algorithms/ai/hash_functions_deep_dive.txt https://www.kirupa.com/data_structures_algorithms/ai/hashtable_hashmap_dictionary.txt https://www.kirupa.com/data_structures_algorithms/ai/heap.txt https://www.kirupa.com/data_structures_algorithms/ai/intro_data_structures_why.txt https://www.kirupa.com/data_structures_algorithms/ai/introduction_book_tutorials.txt https://www.kirupa.com/data_structures_algorithms/ai/introduction_recursion.txt https://www.kirupa.com/data_structures_algorithms/ai/linear_search.txt https://www.kirupa.com/data_structures_algorithms/ai/linked_list.txt https://www.kirupa.com/data_structures_algorithms/ai/linked_list_implementation.txt https://www.kirupa.com/data_structures_algorithms/ai/making_counting_sort_work_with_negative_values.txt https://www.kirupa.com/data_structures_algorithms/ai/monty_hall_problem.txt https://www.kirupa.com/data_structures_algorithms/ai/radix_sort.txt https://www.kirupa.com/data_structures_algorithms/ai/random_walk.txt https://www.kirupa.com/data_structures_algorithms/ai/stability_sorting_algorithms.txt https://www.kirupa.com/data_structures_algorithms/ai/trees.txt https://www.kirupa.com/data_structures_algorithms/ai/tries_prefix_tree.txt https://www.kirupa.com/data_structures_algorithms/ai/understanding_merkle_trees_full.txt https://www.kirupa.com/data_structures_algorithms/ai/visualizing_recursion_sierpinski_triangle.txt ## HTML5 (Markdown) https://www.kirupa.com/html5/ai/3_easy_link_hover_effects_using_transitions_temp.md https://www.kirupa.com/html5/ai/3d_in_css.md https://www.kirupa.com/html5/ai/5_simple_tools_tricks_you_should_use.md https://www.kirupa.com/html5/ai/a_deeper_look_at_objects_in_javascript.md https://www.kirupa.com/html5/ai/accessing_your_webcam_in_html5.md https://www.kirupa.com/html5/ai/adding_reCAPTCHA_to_a_contact_form.md https://www.kirupa.com/html5/ai/advanced_random_numbers_js.md https://www.kirupa.com/html5/ai/all_about_color_in_the_year_2013.md https://www.kirupa.com/html5/ai/all_about_css_animations.md https://www.kirupa.com/html5/ai/all_about_css_transitions.md https://www.kirupa.com/html5/ai/all_about_file_paths.md https://www.kirupa.com/html5/ai/all_about_json.md https://www.kirupa.com/html5/ai/all_about_nth-of-type_and_nth-child.md https://www.kirupa.com/html5/ai/amorphous_circles.md https://www.kirupa.com/html5/ai/anatomy_css_style_101.md https://www.kirupa.com/html5/ai/animate_method_temp.md https://www.kirupa.com/html5/ai/animated_scroll_to_top_with_easing.md https://www.kirupa.com/html5/ai/animating_in_code_using_javascript.md https://www.kirupa.com/html5/ai/animating_in_code_using_javascript2.md https://www.kirupa.com/html5/ai/animating_many_elements_using_transitions.md https://www.kirupa.com/html5/ai/animating_many_things_on_a_canvas.md https://www.kirupa.com/html5/ai/animating_movement_smoothly_using_css.md https://www.kirupa.com/html5/ai/animating_multiple_elements_animate_method.md https://www.kirupa.com/html5/ai/animating_multiple_elements_animate_temp.md https://www.kirupa.com/html5/ai/animating_with_easing_functions_in_javascript.md https://www.kirupa.com/html5/ai/animating_with_requestAnimationFrame.md https://www.kirupa.com/html5/ai/animating_your_links_to_life.md https://www.kirupa.com/html5/ai/animation_loops_using_requestAnimationFrame.md https://www.kirupa.com/html5/ai/animations_and_the_html5_canvas_old.md https://www.kirupa.com/html5/ai/array_tricks.md https://www.kirupa.com/html5/ai/arrays_in_js_temp.md https://www.kirupa.com/html5/ai/arrays_javascript.md https://www.kirupa.com/html5/ai/arrays_map_filter_reduce.md https://www.kirupa.com/html5/ai/arrow_functions.md https://www.kirupa.com/html5/ai/avoid_using_vendor_prefixes.md https://www.kirupa.com/html5/ai/backup_your_site_data_efficiently_like_a_ninja.md https://www.kirupa.com/html5/ai/blurring_in_the_world_of_html_temp.md https://www.kirupa.com/html5/ai/boolean_and_stricter_operators.md https://www.kirupa.com/html5/ai/border_rollovers_without_shifting_temp.md https://www.kirupa.com/html5/ai/building_your_first_web_page.md https://www.kirupa.com/html5/ai/caesar_cipher.md https://www.kirupa.com/html5/ai/centering_a_div_horizontally.md https://www.kirupa.com/html5/ai/centering_vertically_horizontally.md https://www.kirupa.com/html5/ai/changing_css_using_javascript_old.md https://www.kirupa.com/html5/ai/changing_selection_color_using_css.md https://www.kirupa.com/html5/ai/changing_the_default_focus_styles.md https://www.kirupa.com/html5/ai/check_if_internet_connection_exists_in_javascript.md https://www.kirupa.com/html5/ai/check_if_you_are_on_a_touch_enabled_device.md https://www.kirupa.com/html5/ai/checking_if_a_file_exists.md https://www.kirupa.com/html5/ai/child_sibling_selectors_temp.md https://www.kirupa.com/html5/ai/clipping_content_using_css.md https://www.kirupa.com/html5/ai/closures_in_javascript.md https://www.kirupa.com/html5/ai/comments.md https://www.kirupa.com/html5/ai/conditional_statements_if_else_switch_javascript.md https://www.kirupa.com/html5/ai/console.md https://www.kirupa.com/html5/ai/constraining_the_falling_snow_effect.md https://www.kirupa.com/html5/ai/cool_content_carousel.md https://www.kirupa.com/html5/ai/create_an_analog_clock_using_the_canvas.md https://www.kirupa.com/html5/ai/create_an_awesome_contact_page.md https://www.kirupa.com/html5/ai/creating_a_horizontal_css_list_menu.md https://www.kirupa.com/html5/ai/creating_a_smooth_sliding_menu.md https://www.kirupa.com/html5/ai/creating_a_strobe_light_generator.md https://www.kirupa.com/html5/ai/creating_a_sweet_content_slider.md https://www.kirupa.com/html5/ai/creating_a_vertical_css_list_menu.md https://www.kirupa.com/html5/ai/creating_an_awesome_search_box.md https://www.kirupa.com/html5/ai/creating_basic_particle_system.md https://www.kirupa.com/html5/ai/creating_buttery_smooth_animations.md https://www.kirupa.com/html5/ai/creating_circles_using_html_css.md https://www.kirupa.com/html5/ai/creating_colorful_smart_shadows.md https://www.kirupa.com/html5/ai/creating_dom_elements_and_other_stuff.md https://www.kirupa.com/html5/ai/creating_email_contact_form.md https://www.kirupa.com/html5/ai/creating_high_performant_smooth_animations.md https://www.kirupa.com/html5/ai/creating_html_javascript_temp.md https://www.kirupa.com/html5/ai/creating_morph_animation_without_morphing.md https://www.kirupa.com/html5/ai/creating_performant_animations.md https://www.kirupa.com/html5/ai/creating_printer_friendly_pages.md https://www.kirupa.com/html5/ai/creating_simple_html5_canvas_animation.md https://www.kirupa.com/html5/ai/creating_the_ios_icon_jiggle_wobble_effect_in_css.md https://www.kirupa.com/html5/ai/css3_animations_vs_transitions.md https://www.kirupa.com/html5/ai/css_animation_events.md https://www.kirupa.com/html5/ai/css_animations_cheatsheet.md https://www.kirupa.com/html5/ai/css_attribute_selectors.md https://www.kirupa.com/html5/ai/css_cursor_property.md https://www.kirupa.com/html5/ai/css_filters.md https://www.kirupa.com/html5/ai/css_selectors_type_class_id.md https://www.kirupa.com/html5/ai/css_transitions_cheatsheet.md https://www.kirupa.com/html5/ai/css_variables_js_win.md https://www.kirupa.com/html5/ai/custom_data_attributes.md https://www.kirupa.com/html5/ai/custom_events_js.md https://www.kirupa.com/html5/ai/debugging_js_by_using_breakpoints.md https://www.kirupa.com/html5/ai/deconstruction_irritated_bubbles.md https://www.kirupa.com/html5/ai/detect_whether_font_is_installed.md https://www.kirupa.com/html5/ai/detecting_if_the_user_is_idle_or_inactive.md https://www.kirupa.com/html5/ai/detecting_retina_high_dpi.md https://www.kirupa.com/html5/ai/detecting_touch_swipe_gestures.md https://www.kirupa.com/html5/ai/disable_form_autocomplete.md https://www.kirupa.com/html5/ai/display_an_outline_instead_of_a_border_hover.md https://www.kirupa.com/html5/ai/displaying_a_random_image.md https://www.kirupa.com/html5/ai/displaying_php_data_in_html.md https://www.kirupa.com/html5/ai/dom_vs_canvas.md https://www.kirupa.com/html5/ai/drag.md https://www.kirupa.com/html5/ai/drawing_circles_canvas.md https://www.kirupa.com/html5/ai/drawing_curves.md https://www.kirupa.com/html5/ai/drawing_rectangles_squares_canvas.md https://www.kirupa.com/html5/ai/drawing_triangles_on_the_canvas.md https://www.kirupa.com/html5/ai/drop_shadows_in_css3.md https://www.kirupa.com/html5/ai/dynamic_elements.md https://www.kirupa.com/html5/ai/dynamically_create_populate_list.md https://www.kirupa.com/html5/ai/easily_finding_fixing_pixel_sized_issues.md https://www.kirupa.com/html5/ai/easing_functions.md https://www.kirupa.com/html5/ai/easing_functions_css3_new.md https://www.kirupa.com/html5/ai/easing_functions_timing_functions_css3.md https://www.kirupa.com/html5/ai/emoji.md https://www.kirupa.com/html5/ai/event_capturing_bubbling_javascript.md https://www.kirupa.com/html5/ai/event_capturing_bubbling_javascript_old.md https://www.kirupa.com/html5/ai/extending_built_in_objects_javascript.md https://www.kirupa.com/html5/ai/filtering_items_in_a_list.md https://www.kirupa.com/html5/ai/finding_elements_dom_using_querySelector.md https://www.kirupa.com/html5/ai/finding_html_elements_via_javascript.md https://www.kirupa.com/html5/ai/fixing_element_position_css.md https://www.kirupa.com/html5/ai/fizzbuzz.md https://www.kirupa.com/html5/ai/frame_rates_html_javascript.md https://www.kirupa.com/html5/ai/functions_in_javascript.md https://www.kirupa.com/html5/ai/generating_random_boolean_true_false.md https://www.kirupa.com/html5/ai/generating_random_colors.md https://www.kirupa.com/html5/ai/get_element_position_using_javascript.md https://www.kirupa.com/html5/ai/get_the_value_of_css_properties_as_they_are_animating.md https://www.kirupa.com/html5/ai/getting_mouse_click_position.md https://www.kirupa.com/html5/ai/getting_mouse_movement_direction.md https://www.kirupa.com/html5/ai/going_from_a_string_to_a_number.md https://www.kirupa.com/html5/ai/handling_events_for_many_elements.md https://www.kirupa.com/html5/ai/hanging_indents.md https://www.kirupa.com/html5/ai/hashtables_vs_arrays.md https://www.kirupa.com/html5/ai/heaps_temp.md https://www.kirupa.com/html5/ai/hiding_mouse_cursor_after_some_inactivity_temp.md https://www.kirupa.com/html5/ai/hiding_things_using_css.md https://www.kirupa.com/html5/ai/hoisting.md https://www.kirupa.com/html5/ai/htaccess_tricks.md https://www.kirupa.com/html5/ai/html5_starting_template.md https://www.kirupa.com/html5/ai/http_web_requests.md https://www.kirupa.com/html5/ai/if_else.md https://www.kirupa.com/html5/ai/image_carousel.md https://www.kirupa.com/html5/ai/immediately_invoked_function_expressions_iife.md https://www.kirupa.com/html5/ai/inspecting_element_style.md https://www.kirupa.com/html5/ai/intro_to_property_based_animations.md https://www.kirupa.com/html5/ai/introduction_css_animations.md https://www.kirupa.com/html5/ai/introduction_css_transitions.md https://www.kirupa.com/html5/ai/introduction_html.md https://www.kirupa.com/html5/ai/introduction_to_animation_html.md https://www.kirupa.com/html5/ai/introduction_to_easing_in_javascript.md https://www.kirupa.com/html5/ai/introduction_to_javascript.md https://www.kirupa.com/html5/ai/introduction_to_objects_in_javascript.md https://www.kirupa.com/html5/ai/javascript_events.md https://www.kirupa.com/html5/ai/javascript_events_old.md https://www.kirupa.com/html5/ai/javascript_the_browser_and_the_dom.md https://www.kirupa.com/html5/ai/ken_burns_effect_css.md https://www.kirupa.com/html5/ai/keyboard_events_in_javascript.md https://www.kirupa.com/html5/ai/keyframes_and_the_animate_method.md https://www.kirupa.com/html5/ai/konami_code.md https://www.kirupa.com/html5/ai/list_of_css_selectors_temp.md https://www.kirupa.com/html5/ai/loading_data_from_php_temp.md https://www.kirupa.com/html5/ai/loading_script_files_dynamically.md https://www.kirupa.com/html5/ai/looking_at_css3_transitions-old.md https://www.kirupa.com/html5/ai/looping_a_css_transition.md https://www.kirupa.com/html5/ai/loops_in_javascript.md https://www.kirupa.com/html5/ai/make_body_take_up_full_browser_height.md https://www.kirupa.com/html5/ai/making_animations_run_really_smoothly.md https://www.kirupa.com/html5/ai/making_http_requests_js.md https://www.kirupa.com/html5/ai/making_sense_of_timing_functions.md https://www.kirupa.com/html5/ai/making_sense_timing_functions.md https://www.kirupa.com/html5/ai/making_the_first_letter_stand_out.md https://www.kirupa.com/html5/ai/managing_dependencies_with_requirejs.md https://www.kirupa.com/html5/ai/modifying_dom_elements.md https://www.kirupa.com/html5/ai/mouse_events_in_javascript.md https://www.kirupa.com/html5/ai/mouse_movement_direction_temp.md https://www.kirupa.com/html5/ai/naming_via_class_id_name.md https://www.kirupa.com/html5/ai/null_and_undefined.md https://www.kirupa.com/html5/ai/numbers_in_javascript.md https://www.kirupa.com/html5/ai/objects_classes_javascript.md https://www.kirupa.com/html5/ai/objects_everywhere_temp.md https://www.kirupa.com/html5/ai/of_pizza_types_primitives_and_objects.md https://www.kirupa.com/html5/ai/oop_javascript_objects.md https://www.kirupa.com/html5/ai/page_navigation_on_click.md https://www.kirupa.com/html5/ai/picking_random_item_from_array.md https://www.kirupa.com/html5/ai/playing_sound_audio_element.md https://www.kirupa.com/html5/ai/preloading_images.md https://www.kirupa.com/html5/ai/preserve_an_image_aspect_ratio_when_resized.md https://www.kirupa.com/html5/ai/press_and_hold.md https://www.kirupa.com/html5/ai/queues_in_javascript.md https://www.kirupa.com/html5/ai/random_numbers_js.md https://www.kirupa.com/html5/ai/randomly_generated_sound_web_audio_api.md https://www.kirupa.com/html5/ai/reading_xml_javascript_temp.md https://www.kirupa.com/html5/ai/relative_urls_and_absolute_urls.md https://www.kirupa.com/html5/ai/removing_duplicate_items_from_an_array.md https://www.kirupa.com/html5/ai/removing_space_between_images_using_css.md https://www.kirupa.com/html5/ai/resizing_html_canvas_element.md https://www.kirupa.com/html5/ai/revisiting_some_tags_html5.md https://www.kirupa.com/html5/ai/rounded_image_links_with_a_sweet_hover_effect.md https://www.kirupa.com/html5/ai/rounding_corners_css3.md https://www.kirupa.com/html5/ai/rounding_numbers_in_javascript.md https://www.kirupa.com/html5/ai/running_scripts_after_your_content_has_loaded-old.md https://www.kirupa.com/html5/ai/running_your_code_at_the_right_time.md https://www.kirupa.com/html5/ai/setinterval_vs_requestAnimationFrame.md https://www.kirupa.com/html5/ai/setting_css_styles_using_javascript.md https://www.kirupa.com/html5/ai/settings_translate3d_in_javascript_temp.md https://www.kirupa.com/html5/ai/shuffling_array_js.md https://www.kirupa.com/html5/ai/simple_text_fade_and_scale_animation.md https://www.kirupa.com/html5/ai/simple_video_chat_with_webrtc.md https://www.kirupa.com/html5/ai/slide_image_hover_using_css3.md https://www.kirupa.com/html5/ai/sliding_background_effect_on_link_hover.md https://www.kirupa.com/html5/ai/smooth_parallax_scrolling.md https://www.kirupa.com/html5/ai/smooth_parallax_scrolling_v2.md https://www.kirupa.com/html5/ai/source_dom_vs_runtime_dom.md https://www.kirupa.com/html5/ai/sprite_sheet_animations_using_only_css.md https://www.kirupa.com/html5/ai/stacks_in_javascript.md https://www.kirupa.com/html5/ai/stacks_queue_js.md https://www.kirupa.com/html5/ai/starting_point_mobile_touch.md https://www.kirupa.com/html5/ai/storing_and_retrieving_an_array_from_local_storage.md https://www.kirupa.com/html5/ai/strings_in_javascript.md https://www.kirupa.com/html5/ai/strings_in_js_temp.md https://www.kirupa.com/html5/ai/style_beautiful_tables_using_only_css.md https://www.kirupa.com/html5/ai/styling_links_in_css.md https://www.kirupa.com/html5/ai/styling_placeholder_text_css.md https://www.kirupa.com/html5/ai/swapping_items_array_js.md https://www.kirupa.com/html5/ai/switch_statements_javascript.md https://www.kirupa.com/html5/ai/testimport.md https://www.kirupa.com/html5/ai/the_animate_blue_circles_contest.md https://www.kirupa.com/html5/ai/the_battery_status_api_js.md https://www.kirupa.com/html5/ai/the_blink_tag_shall_live_on.md https://www.kirupa.com/html5/ai/the_cascade_temp.md https://www.kirupa.com/html5/ai/the_devowelizer.md https://www.kirupa.com/html5/ai/the_falling_snow_effect.md https://www.kirupa.com/html5/ai/the_transitionend_event.md https://www.kirupa.com/html5/ai/timers_js.md https://www.kirupa.com/html5/ai/timing_functions.md https://www.kirupa.com/html5/ai/toggling_animations_on_off.md https://www.kirupa.com/html5/ai/totally_awesome_analog_clock.md https://www.kirupa.com/html5/ai/tower_of_hanoi_puzzle.md https://www.kirupa.com/html5/ai/traversing_the_dom.md https://www.kirupa.com/html5/ai/triggering_animations_javascript.md https://www.kirupa.com/html5/ai/using_firebug_easily_inspect_diagnose_css.md https://www.kirupa.com/html5/ai/using_js_prototype_to_add_new_properties.md https://www.kirupa.com/html5/ai/using_robert_penner_easing_equations_temp.md https://www.kirupa.com/html5/ai/using_the_classlist_api.md https://www.kirupa.com/html5/ai/using_the_pythagorean_theorem_to_measure_distance.md https://www.kirupa.com/html5/ai/valueof_temp.md https://www.kirupa.com/html5/ai/variable_hoisting.md https://www.kirupa.com/html5/ai/variable_scope_js.md https://www.kirupa.com/html5/ai/variables_in_javascript.md https://www.kirupa.com/html5/ai/vendor_prefixes_javascript.md https://www.kirupa.com/html5/ai/viewport_device_document_size.md https://www.kirupa.com/html5/ai/web_animations_animate_method.md https://www.kirupa.com/html5/ai/when_primitives_behave_like_objects.md https://www.kirupa.com/html5/ai/where_should_your_code_live.md https://www.kirupa.com/html5/ai/where_will_your_styles_live.md https://www.kirupa.com/html5/ai/wrapping_div_elements_new_line_temp.md ## HTML5 (Plain Text Versions) https://www.kirupa.com/html5/ai/3_easy_link_hover_effects_using_transitions_temp.txt https://www.kirupa.com/html5/ai/3d_in_css.txt https://www.kirupa.com/html5/ai/5_simple_tools_tricks_you_should_use.txt https://www.kirupa.com/html5/ai/a_deeper_look_at_objects_in_javascript.txt https://www.kirupa.com/html5/ai/accessing_your_webcam_in_html5.txt https://www.kirupa.com/html5/ai/adding_reCAPTCHA_to_a_contact_form.txt https://www.kirupa.com/html5/ai/advanced_random_numbers_js.txt https://www.kirupa.com/html5/ai/all_about_color_in_the_year_2013.txt https://www.kirupa.com/html5/ai/all_about_css_animations.txt https://www.kirupa.com/html5/ai/all_about_css_transitions.txt https://www.kirupa.com/html5/ai/all_about_file_paths.txt https://www.kirupa.com/html5/ai/all_about_json.txt https://www.kirupa.com/html5/ai/all_about_nth-of-type_and_nth-child.txt https://www.kirupa.com/html5/ai/amorphous_circles.txt https://www.kirupa.com/html5/ai/anatomy_css_style_101.txt https://www.kirupa.com/html5/ai/animate_method_temp.txt https://www.kirupa.com/html5/ai/animated_scroll_to_top_with_easing.txt https://www.kirupa.com/html5/ai/animating_in_code_using_javascript.txt https://www.kirupa.com/html5/ai/animating_in_code_using_javascript2.txt https://www.kirupa.com/html5/ai/animating_many_elements_using_transitions.txt https://www.kirupa.com/html5/ai/animating_many_things_on_a_canvas.txt https://www.kirupa.com/html5/ai/animating_movement_smoothly_using_css.txt https://www.kirupa.com/html5/ai/animating_multiple_elements_animate_method.txt https://www.kirupa.com/html5/ai/animating_multiple_elements_animate_temp.txt https://www.kirupa.com/html5/ai/animating_with_easing_functions_in_javascript.txt https://www.kirupa.com/html5/ai/animating_with_requestAnimationFrame.txt https://www.kirupa.com/html5/ai/animating_your_links_to_life.txt https://www.kirupa.com/html5/ai/animation_loops_using_requestAnimationFrame.txt https://www.kirupa.com/html5/ai/animations_and_the_html5_canvas_old.txt https://www.kirupa.com/html5/ai/array_tricks.txt https://www.kirupa.com/html5/ai/arrays_in_js_temp.txt https://www.kirupa.com/html5/ai/arrays_javascript.txt https://www.kirupa.com/html5/ai/arrays_map_filter_reduce.txt https://www.kirupa.com/html5/ai/arrow_functions.txt https://www.kirupa.com/html5/ai/avoid_using_vendor_prefixes.txt https://www.kirupa.com/html5/ai/backup_your_site_data_efficiently_like_a_ninja.txt https://www.kirupa.com/html5/ai/blurring_in_the_world_of_html_temp.txt https://www.kirupa.com/html5/ai/boolean_and_stricter_operators.txt https://www.kirupa.com/html5/ai/border_rollovers_without_shifting_temp.txt https://www.kirupa.com/html5/ai/building_your_first_web_page.txt https://www.kirupa.com/html5/ai/caesar_cipher.txt https://www.kirupa.com/html5/ai/centering_a_div_horizontally.txt https://www.kirupa.com/html5/ai/centering_vertically_horizontally.txt https://www.kirupa.com/html5/ai/changing_css_using_javascript_old.txt https://www.kirupa.com/html5/ai/changing_selection_color_using_css.txt https://www.kirupa.com/html5/ai/changing_the_default_focus_styles.txt https://www.kirupa.com/html5/ai/check_if_internet_connection_exists_in_javascript.txt https://www.kirupa.com/html5/ai/check_if_you_are_on_a_touch_enabled_device.txt https://www.kirupa.com/html5/ai/checking_if_a_file_exists.txt https://www.kirupa.com/html5/ai/child_sibling_selectors_temp.txt https://www.kirupa.com/html5/ai/clipping_content_using_css.txt https://www.kirupa.com/html5/ai/closures_in_javascript.txt https://www.kirupa.com/html5/ai/comments.txt https://www.kirupa.com/html5/ai/conditional_statements_if_else_switch_javascript.txt https://www.kirupa.com/html5/ai/console.txt https://www.kirupa.com/html5/ai/constraining_the_falling_snow_effect.txt https://www.kirupa.com/html5/ai/cool_content_carousel.txt https://www.kirupa.com/html5/ai/create_an_analog_clock_using_the_canvas.txt https://www.kirupa.com/html5/ai/create_an_awesome_contact_page.txt https://www.kirupa.com/html5/ai/creating_a_horizontal_css_list_menu.txt https://www.kirupa.com/html5/ai/creating_a_smooth_sliding_menu.txt https://www.kirupa.com/html5/ai/creating_a_strobe_light_generator.txt https://www.kirupa.com/html5/ai/creating_a_sweet_content_slider.txt https://www.kirupa.com/html5/ai/creating_a_vertical_css_list_menu.txt https://www.kirupa.com/html5/ai/creating_an_awesome_search_box.txt https://www.kirupa.com/html5/ai/creating_basic_particle_system.txt https://www.kirupa.com/html5/ai/creating_buttery_smooth_animations.txt https://www.kirupa.com/html5/ai/creating_circles_using_html_css.txt https://www.kirupa.com/html5/ai/creating_colorful_smart_shadows.txt https://www.kirupa.com/html5/ai/creating_dom_elements_and_other_stuff.txt https://www.kirupa.com/html5/ai/creating_email_contact_form.txt https://www.kirupa.com/html5/ai/creating_high_performant_smooth_animations.txt https://www.kirupa.com/html5/ai/creating_html_javascript_temp.txt https://www.kirupa.com/html5/ai/creating_morph_animation_without_morphing.txt https://www.kirupa.com/html5/ai/creating_performant_animations.txt https://www.kirupa.com/html5/ai/creating_printer_friendly_pages.txt https://www.kirupa.com/html5/ai/creating_simple_html5_canvas_animation.txt https://www.kirupa.com/html5/ai/creating_the_ios_icon_jiggle_wobble_effect_in_css.txt https://www.kirupa.com/html5/ai/css3_animations_vs_transitions.txt https://www.kirupa.com/html5/ai/css_animation_events.txt https://www.kirupa.com/html5/ai/css_animations_cheatsheet.txt https://www.kirupa.com/html5/ai/css_attribute_selectors.txt https://www.kirupa.com/html5/ai/css_cursor_property.txt https://www.kirupa.com/html5/ai/css_filters.txt https://www.kirupa.com/html5/ai/css_selectors_type_class_id.txt https://www.kirupa.com/html5/ai/css_transitions_cheatsheet.txt https://www.kirupa.com/html5/ai/css_variables_js_win.txt https://www.kirupa.com/html5/ai/custom_data_attributes.txt https://www.kirupa.com/html5/ai/custom_events_js.txt https://www.kirupa.com/html5/ai/debugging_js_by_using_breakpoints.txt https://www.kirupa.com/html5/ai/deconstruction_irritated_bubbles.txt https://www.kirupa.com/html5/ai/detect_whether_font_is_installed.txt https://www.kirupa.com/html5/ai/detecting_if_the_user_is_idle_or_inactive.txt https://www.kirupa.com/html5/ai/detecting_retina_high_dpi.txt https://www.kirupa.com/html5/ai/detecting_touch_swipe_gestures.txt https://www.kirupa.com/html5/ai/disable_form_autocomplete.txt https://www.kirupa.com/html5/ai/display_an_outline_instead_of_a_border_hover.txt https://www.kirupa.com/html5/ai/displaying_a_random_image.txt https://www.kirupa.com/html5/ai/displaying_php_data_in_html.txt https://www.kirupa.com/html5/ai/dom_vs_canvas.txt https://www.kirupa.com/html5/ai/drag.txt https://www.kirupa.com/html5/ai/drawing_circles_canvas.txt https://www.kirupa.com/html5/ai/drawing_curves.txt https://www.kirupa.com/html5/ai/drawing_rectangles_squares_canvas.txt https://www.kirupa.com/html5/ai/drawing_triangles_on_the_canvas.txt https://www.kirupa.com/html5/ai/drop_shadows_in_css3.txt https://www.kirupa.com/html5/ai/dynamic_elements.txt https://www.kirupa.com/html5/ai/dynamically_create_populate_list.txt https://www.kirupa.com/html5/ai/easily_finding_fixing_pixel_sized_issues.txt https://www.kirupa.com/html5/ai/easing_functions.txt https://www.kirupa.com/html5/ai/easing_functions_css3_new.txt https://www.kirupa.com/html5/ai/easing_functions_timing_functions_css3.txt https://www.kirupa.com/html5/ai/emoji.txt https://www.kirupa.com/html5/ai/event_capturing_bubbling_javascript.txt https://www.kirupa.com/html5/ai/event_capturing_bubbling_javascript_old.txt https://www.kirupa.com/html5/ai/extending_built_in_objects_javascript.txt https://www.kirupa.com/html5/ai/filtering_items_in_a_list.txt https://www.kirupa.com/html5/ai/finding_elements_dom_using_querySelector.txt https://www.kirupa.com/html5/ai/finding_html_elements_via_javascript.txt https://www.kirupa.com/html5/ai/fixing_element_position_css.txt https://www.kirupa.com/html5/ai/fizzbuzz.txt https://www.kirupa.com/html5/ai/frame_rates_html_javascript.txt https://www.kirupa.com/html5/ai/functions_in_javascript.txt https://www.kirupa.com/html5/ai/generating_random_boolean_true_false.txt https://www.kirupa.com/html5/ai/generating_random_colors.txt https://www.kirupa.com/html5/ai/get_element_position_using_javascript.txt https://www.kirupa.com/html5/ai/get_the_value_of_css_properties_as_they_are_animating.txt https://www.kirupa.com/html5/ai/getting_mouse_click_position.txt https://www.kirupa.com/html5/ai/getting_mouse_movement_direction.txt https://www.kirupa.com/html5/ai/going_from_a_string_to_a_number.txt https://www.kirupa.com/html5/ai/handling_events_for_many_elements.txt https://www.kirupa.com/html5/ai/hanging_indents.txt https://www.kirupa.com/html5/ai/hashtables_vs_arrays.txt https://www.kirupa.com/html5/ai/heaps_temp.txt https://www.kirupa.com/html5/ai/hiding_mouse_cursor_after_some_inactivity_temp.txt https://www.kirupa.com/html5/ai/hiding_things_using_css.txt https://www.kirupa.com/html5/ai/hoisting.txt https://www.kirupa.com/html5/ai/htaccess_tricks.txt https://www.kirupa.com/html5/ai/html5_starting_template.txt https://www.kirupa.com/html5/ai/http_web_requests.txt https://www.kirupa.com/html5/ai/if_else.txt https://www.kirupa.com/html5/ai/image_carousel.txt https://www.kirupa.com/html5/ai/immediately_invoked_function_expressions_iife.txt https://www.kirupa.com/html5/ai/inspecting_element_style.txt https://www.kirupa.com/html5/ai/intro_to_property_based_animations.txt https://www.kirupa.com/html5/ai/introduction_css_animations.txt https://www.kirupa.com/html5/ai/introduction_css_transitions.txt https://www.kirupa.com/html5/ai/introduction_html.txt https://www.kirupa.com/html5/ai/introduction_to_animation_html.txt https://www.kirupa.com/html5/ai/introduction_to_easing_in_javascript.txt https://www.kirupa.com/html5/ai/introduction_to_javascript.txt https://www.kirupa.com/html5/ai/introduction_to_objects_in_javascript.txt https://www.kirupa.com/html5/ai/javascript_events.txt https://www.kirupa.com/html5/ai/javascript_events_old.txt https://www.kirupa.com/html5/ai/javascript_the_browser_and_the_dom.txt https://www.kirupa.com/html5/ai/ken_burns_effect_css.txt https://www.kirupa.com/html5/ai/keyboard_events_in_javascript.txt https://www.kirupa.com/html5/ai/keyframes_and_the_animate_method.txt https://www.kirupa.com/html5/ai/konami_code.txt https://www.kirupa.com/html5/ai/list_of_css_selectors_temp.txt https://www.kirupa.com/html5/ai/loading_data_from_php_temp.txt https://www.kirupa.com/html5/ai/loading_script_files_dynamically.txt https://www.kirupa.com/html5/ai/looking_at_css3_transitions-old.txt https://www.kirupa.com/html5/ai/looping_a_css_transition.txt https://www.kirupa.com/html5/ai/loops_in_javascript.txt https://www.kirupa.com/html5/ai/make_body_take_up_full_browser_height.txt https://www.kirupa.com/html5/ai/making_animations_run_really_smoothly.txt https://www.kirupa.com/html5/ai/making_http_requests_js.txt https://www.kirupa.com/html5/ai/making_sense_of_timing_functions.txt https://www.kirupa.com/html5/ai/making_sense_timing_functions.txt https://www.kirupa.com/html5/ai/making_the_first_letter_stand_out.txt https://www.kirupa.com/html5/ai/managing_dependencies_with_requirejs.txt https://www.kirupa.com/html5/ai/modifying_dom_elements.txt https://www.kirupa.com/html5/ai/mouse_events_in_javascript.txt https://www.kirupa.com/html5/ai/mouse_movement_direction_temp.txt https://www.kirupa.com/html5/ai/naming_via_class_id_name.txt https://www.kirupa.com/html5/ai/null_and_undefined.txt https://www.kirupa.com/html5/ai/numbers_in_javascript.txt https://www.kirupa.com/html5/ai/objects_classes_javascript.txt https://www.kirupa.com/html5/ai/objects_everywhere_temp.txt https://www.kirupa.com/html5/ai/of_pizza_types_primitives_and_objects.txt https://www.kirupa.com/html5/ai/oop_javascript_objects.txt https://www.kirupa.com/html5/ai/page_navigation_on_click.txt https://www.kirupa.com/html5/ai/picking_random_item_from_array.txt https://www.kirupa.com/html5/ai/playing_sound_audio_element.txt https://www.kirupa.com/html5/ai/preloading_images.txt https://www.kirupa.com/html5/ai/preserve_an_image_aspect_ratio_when_resized.txt https://www.kirupa.com/html5/ai/press_and_hold.txt https://www.kirupa.com/html5/ai/queues_in_javascript.txt https://www.kirupa.com/html5/ai/random_numbers_js.txt https://www.kirupa.com/html5/ai/randomly_generated_sound_web_audio_api.txt https://www.kirupa.com/html5/ai/reading_xml_javascript_temp.txt https://www.kirupa.com/html5/ai/relative_urls_and_absolute_urls.txt https://www.kirupa.com/html5/ai/removing_duplicate_items_from_an_array.txt https://www.kirupa.com/html5/ai/removing_space_between_images_using_css.txt https://www.kirupa.com/html5/ai/resizing_html_canvas_element.txt https://www.kirupa.com/html5/ai/revisiting_some_tags_html5.txt https://www.kirupa.com/html5/ai/rounded_image_links_with_a_sweet_hover_effect.txt https://www.kirupa.com/html5/ai/rounding_corners_css3.txt https://www.kirupa.com/html5/ai/rounding_numbers_in_javascript.txt https://www.kirupa.com/html5/ai/running_scripts_after_your_content_has_loaded-old.txt https://www.kirupa.com/html5/ai/running_your_code_at_the_right_time.txt https://www.kirupa.com/html5/ai/setinterval_vs_requestAnimationFrame.txt https://www.kirupa.com/html5/ai/setting_css_styles_using_javascript.txt https://www.kirupa.com/html5/ai/settings_translate3d_in_javascript_temp.txt https://www.kirupa.com/html5/ai/shuffling_array_js.txt https://www.kirupa.com/html5/ai/simple_text_fade_and_scale_animation.txt https://www.kirupa.com/html5/ai/simple_video_chat_with_webrtc.txt https://www.kirupa.com/html5/ai/slide_image_hover_using_css3.txt https://www.kirupa.com/html5/ai/sliding_background_effect_on_link_hover.txt https://www.kirupa.com/html5/ai/smooth_parallax_scrolling.txt https://www.kirupa.com/html5/ai/smooth_parallax_scrolling_v2.txt https://www.kirupa.com/html5/ai/source_dom_vs_runtime_dom.txt https://www.kirupa.com/html5/ai/sprite_sheet_animations_using_only_css.txt https://www.kirupa.com/html5/ai/stacks_in_javascript.txt https://www.kirupa.com/html5/ai/stacks_queue_js.txt https://www.kirupa.com/html5/ai/starting_point_mobile_touch.txt https://www.kirupa.com/html5/ai/storing_and_retrieving_an_array_from_local_storage.txt https://www.kirupa.com/html5/ai/strings_in_javascript.txt https://www.kirupa.com/html5/ai/strings_in_js_temp.txt https://www.kirupa.com/html5/ai/style_beautiful_tables_using_only_css.txt https://www.kirupa.com/html5/ai/styling_links_in_css.txt https://www.kirupa.com/html5/ai/styling_placeholder_text_css.txt https://www.kirupa.com/html5/ai/swapping_items_array_js.txt https://www.kirupa.com/html5/ai/switch_statements_javascript.txt https://www.kirupa.com/html5/ai/testimport.txt https://www.kirupa.com/html5/ai/the_animate_blue_circles_contest.txt https://www.kirupa.com/html5/ai/the_battery_status_api_js.txt https://www.kirupa.com/html5/ai/the_blink_tag_shall_live_on.txt https://www.kirupa.com/html5/ai/the_cascade_temp.txt https://www.kirupa.com/html5/ai/the_devowelizer.txt https://www.kirupa.com/html5/ai/the_falling_snow_effect.txt https://www.kirupa.com/html5/ai/the_transitionend_event.txt https://www.kirupa.com/html5/ai/timers_js.txt https://www.kirupa.com/html5/ai/timing_functions.txt https://www.kirupa.com/html5/ai/toggling_animations_on_off.txt https://www.kirupa.com/html5/ai/totally_awesome_analog_clock.txt https://www.kirupa.com/html5/ai/tower_of_hanoi_puzzle.txt https://www.kirupa.com/html5/ai/traversing_the_dom.txt https://www.kirupa.com/html5/ai/triggering_animations_javascript.txt https://www.kirupa.com/html5/ai/using_firebug_easily_inspect_diagnose_css.txt https://www.kirupa.com/html5/ai/using_js_prototype_to_add_new_properties.txt https://www.kirupa.com/html5/ai/using_robert_penner_easing_equations_temp.txt https://www.kirupa.com/html5/ai/using_the_classlist_api.txt https://www.kirupa.com/html5/ai/using_the_pythagorean_theorem_to_measure_distance.txt https://www.kirupa.com/html5/ai/valueof_temp.txt https://www.kirupa.com/html5/ai/variable_hoisting.txt https://www.kirupa.com/html5/ai/variable_scope_js.txt https://www.kirupa.com/html5/ai/variables_in_javascript.txt https://www.kirupa.com/html5/ai/vendor_prefixes_javascript.txt https://www.kirupa.com/html5/ai/viewport_device_document_size.txt https://www.kirupa.com/html5/ai/web_animations_animate_method.txt https://www.kirupa.com/html5/ai/when_primitives_behave_like_objects.txt https://www.kirupa.com/html5/ai/where_should_your_code_live.txt https://www.kirupa.com/html5/ai/where_will_your_styles_live.txt https://www.kirupa.com/html5/ai/wrapping_div_elements_new_line_temp.txt ## Canvas (Markdown) https://www.kirupa.com/canvas/ai/adding_color.md https://www.kirupa.com/canvas/ai/animating_grid.md https://www.kirupa.com/canvas/ai/canvas_high_dpi_retina.md https://www.kirupa.com/canvas/ai/canvas_transformations.md https://www.kirupa.com/canvas/ai/changing_how_lines_meet.md https://www.kirupa.com/canvas/ai/creating_a_fullscreen_grid.md https://www.kirupa.com/canvas/ai/creating_animations_canvas.md https://www.kirupa.com/canvas/ai/creating_motion_trails.md https://www.kirupa.com/canvas/ai/drawing_basics_canvas.md https://www.kirupa.com/canvas/ai/drawing_curves.md https://www.kirupa.com/canvas/ai/drawing_images.md https://www.kirupa.com/canvas/ai/drawing_multiple_things.md https://www.kirupa.com/canvas/ai/drawing_paths.md https://www.kirupa.com/canvas/ai/drawing_perfect_grid.md https://www.kirupa.com/canvas/ai/drawing_shapes_functions.md https://www.kirupa.com/canvas/ai/drawing_sharp_lines_canvas.md https://www.kirupa.com/canvas/ai/drawing_text.md https://www.kirupa.com/canvas/ai/easily_draw_any_polygon.md https://www.kirupa.com/canvas/ai/follow_mouse_cursor.md https://www.kirupa.com/canvas/ai/from_pixels_to_objects.md https://www.kirupa.com/canvas/ai/getting_exact_mouse_coordinates_canvas.md https://www.kirupa.com/canvas/ai/getting_started_canvas.md https://www.kirupa.com/canvas/ai/modifying_how_corners_look.md https://www.kirupa.com/canvas/ai/mouse_follow_ease.md https://www.kirupa.com/canvas/ai/move_things_using_keyboard.md https://www.kirupa.com/canvas/ai/moving_shapes_canvas_keyboard.md https://www.kirupa.com/canvas/ai/sprite_animations_canvas.md https://www.kirupa.com/canvas/ai/structuring_your_drawing_code.md https://www.kirupa.com/canvas/ai/working_with_colors.md https://www.kirupa.com/canvas/ai/working_with_the_mouse.md ## Canvas (Plain Text Versions) https://www.kirupa.com/canvas/ai/adding_color.txt https://www.kirupa.com/canvas/ai/animating_grid.txt https://www.kirupa.com/canvas/ai/canvas_high_dpi_retina.txt https://www.kirupa.com/canvas/ai/canvas_transformations.txt https://www.kirupa.com/canvas/ai/changing_how_lines_meet.txt https://www.kirupa.com/canvas/ai/creating_a_fullscreen_grid.txt https://www.kirupa.com/canvas/ai/creating_animations_canvas.txt https://www.kirupa.com/canvas/ai/creating_motion_trails.txt https://www.kirupa.com/canvas/ai/drawing_basics_canvas.txt https://www.kirupa.com/canvas/ai/drawing_curves.txt https://www.kirupa.com/canvas/ai/drawing_images.txt https://www.kirupa.com/canvas/ai/drawing_multiple_things.txt https://www.kirupa.com/canvas/ai/drawing_paths.txt https://www.kirupa.com/canvas/ai/drawing_perfect_grid.txt https://www.kirupa.com/canvas/ai/drawing_shapes_functions.txt https://www.kirupa.com/canvas/ai/drawing_sharp_lines_canvas.txt https://www.kirupa.com/canvas/ai/drawing_text.txt https://www.kirupa.com/canvas/ai/easily_draw_any_polygon.txt https://www.kirupa.com/canvas/ai/follow_mouse_cursor.txt https://www.kirupa.com/canvas/ai/from_pixels_to_objects.txt https://www.kirupa.com/canvas/ai/getting_exact_mouse_coordinates_canvas.txt https://www.kirupa.com/canvas/ai/getting_started_canvas.txt https://www.kirupa.com/canvas/ai/modifying_how_corners_look.txt https://www.kirupa.com/canvas/ai/mouse_follow_ease.txt https://www.kirupa.com/canvas/ai/move_things_using_keyboard.txt https://www.kirupa.com/canvas/ai/moving_shapes_canvas_keyboard.txt https://www.kirupa.com/canvas/ai/sprite_animations_canvas.txt https://www.kirupa.com/canvas/ai/structuring_your_drawing_code.txt https://www.kirupa.com/canvas/ai/working_with_colors.txt https://www.kirupa.com/canvas/ai/working_with_the_mouse.txt ## JavaScript (Markdown) https://www.kirupa.com/javascript/ai/arrays_and_objects.md https://www.kirupa.com/javascript/ai/arrow_functions.md https://www.kirupa.com/javascript/ai/detecting_browser_zoom_changes.md ## JavaScript (Plain Text Versions) https://www.kirupa.com/javascript/ai/arrays_and_objects.txt https://www.kirupa.com/javascript/ai/arrow_functions.txt https://www.kirupa.com/javascript/ai/detecting_browser_zoom_changes.txt ## Animations (Markdown) https://www.kirupa.com/animations/ai/animated_3d_starfield_effect.md https://www.kirupa.com/animations/ai/animating_circular_concentric_stripes.md https://www.kirupa.com/animations/ai/animating_drop_shadows.md https://www.kirupa.com/animations/ai/bad_idea_animating_text_size_scale.md https://www.kirupa.com/animations/ai/cluster_growth_animation.md https://www.kirupa.com/animations/ai/color_changing_bouncing_square.md https://www.kirupa.com/animations/ai/creating_pulsing_circle_animation.md https://www.kirupa.com/animations/ai/creating_scroll_activated_animations.md https://www.kirupa.com/animations/ai/creating_scroll_activation_animations.md https://www.kirupa.com/animations/ai/css_animation_vs_raf.md https://www.kirupa.com/animations/ai/customizing_css_animations.md https://www.kirupa.com/animations/ai/ensuring_consistent_animation_speeds.md https://www.kirupa.com/animations/ai/importance_of_frame_rate.md https://www.kirupa.com/animations/ai/infinite_sliding_animation.md https://www.kirupa.com/animations/ai/radial_gradient_stripes.md https://www.kirupa.com/animations/ai/restarting_css_animations.md https://www.kirupa.com/animations/ai/rotating_items_around_a_point.md https://www.kirupa.com/animations/ai/spinning_circular_text.md https://www.kirupa.com/animations/ai/trig.md https://www.kirupa.com/animations/ai/trig2.md ## Animations (Plain Text Versions) https://www.kirupa.com/animations/ai/animated_3d_starfield_effect.txt https://www.kirupa.com/animations/ai/animating_circular_concentric_stripes.txt https://www.kirupa.com/animations/ai/animating_drop_shadows.txt https://www.kirupa.com/animations/ai/bad_idea_animating_text_size_scale.txt https://www.kirupa.com/animations/ai/cluster_growth_animation.txt https://www.kirupa.com/animations/ai/color_changing_bouncing_square.txt https://www.kirupa.com/animations/ai/creating_pulsing_circle_animation.txt https://www.kirupa.com/animations/ai/creating_scroll_activated_animations.txt https://www.kirupa.com/animations/ai/creating_scroll_activation_animations.txt https://www.kirupa.com/animations/ai/css_animation_vs_raf.txt https://www.kirupa.com/animations/ai/customizing_css_animations.txt https://www.kirupa.com/animations/ai/ensuring_consistent_animation_speeds.txt https://www.kirupa.com/animations/ai/importance_of_frame_rate.txt https://www.kirupa.com/animations/ai/infinite_sliding_animation.txt https://www.kirupa.com/animations/ai/radial_gradient_stripes.txt https://www.kirupa.com/animations/ai/restarting_css_animations.txt https://www.kirupa.com/animations/ai/rotating_items_around_a_point.txt https://www.kirupa.com/animations/ai/spinning_circular_text.txt https://www.kirupa.com/animations/ai/trig.txt https://www.kirupa.com/animations/ai/trig2.txt ## Coding Exercises (Markdown) https://www.kirupa.com/codingexercises/ai/12days_of_christmas.md https://www.kirupa.com/codingexercises/ai/99bottles_beer_wall.md https://www.kirupa.com/codingexercises/ai/advanced_glitch_effect.md https://www.kirupa.com/codingexercises/ai/ascii_pyramid.md https://www.kirupa.com/codingexercises/ai/custom_mouse_cursor.md https://www.kirupa.com/codingexercises/ai/display_random_image_unsplash.md https://www.kirupa.com/codingexercises/ai/eyes_follow_mouse.md https://www.kirupa.com/codingexercises/ai/fizzbuzz.md https://www.kirupa.com/codingexercises/ai/guess_the_number.md https://www.kirupa.com/codingexercises/ai/sort_names_alphabetically.md https://www.kirupa.com/codingexercises/ai/sum_arrays.md https://www.kirupa.com/codingexercises/ai/todolist.md ## Coding Exercises (Plain Text Versions) https://www.kirupa.com/codingexercises/ai/12days_of_christmas.txt https://www.kirupa.com/codingexercises/ai/99bottles_beer_wall.txt https://www.kirupa.com/codingexercises/ai/advanced_glitch_effect.txt https://www.kirupa.com/codingexercises/ai/ascii_pyramid.txt https://www.kirupa.com/codingexercises/ai/custom_mouse_cursor.txt https://www.kirupa.com/codingexercises/ai/display_random_image_unsplash.txt https://www.kirupa.com/codingexercises/ai/eyes_follow_mouse.txt https://www.kirupa.com/codingexercises/ai/fizzbuzz.txt https://www.kirupa.com/codingexercises/ai/guess_the_number.txt https://www.kirupa.com/codingexercises/ai/sort_names_alphabetically.txt https://www.kirupa.com/codingexercises/ai/sum_arrays.txt https://www.kirupa.com/codingexercises/ai/todolist.txt ## Sorts (Markdown) https://www.kirupa.com/sorts/ai/bubblesort.md https://www.kirupa.com/sorts/ai/heapsort_temp.md https://www.kirupa.com/sorts/ai/insertionsort.md https://www.kirupa.com/sorts/ai/mergesort.md https://www.kirupa.com/sorts/ai/mergesort_temp.md https://www.kirupa.com/sorts/ai/quicksort.md https://www.kirupa.com/sorts/ai/selectionsort.md https://www.kirupa.com/sorts/ai/timsort.md ## Sorts (Plain Text Versions) https://www.kirupa.com/sorts/ai/bubblesort.txt https://www.kirupa.com/sorts/ai/heapsort_temp.txt https://www.kirupa.com/sorts/ai/insertionsort.txt https://www.kirupa.com/sorts/ai/mergesort.txt https://www.kirupa.com/sorts/ai/mergesort_temp.txt https://www.kirupa.com/sorts/ai/quicksort.txt https://www.kirupa.com/sorts/ai/selectionsort.txt https://www.kirupa.com/sorts/ai/timsort.txt ## Hodgepodge (Markdown) https://www.kirupa.com/hodgepodge/ai/chrome_dev_tools_for_frontend_developers.md https://www.kirupa.com/hodgepodge/ai/compiling_transpiling.md https://www.kirupa.com/hodgepodge/ai/cookies_local_session_storage.md https://www.kirupa.com/hodgepodge/ai/counting_binary_hexadecimal.md https://www.kirupa.com/hodgepodge/ai/counting_hexadecimal.md https://www.kirupa.com/hodgepodge/ai/counting_negabinary.md https://www.kirupa.com/hodgepodge/ai/fun_look_calculating_pi.md https://www.kirupa.com/hodgepodge/ai/google_tips_every_developer_should_know.md https://www.kirupa.com/hodgepodge/ai/if_you_wait_long_enough_perf_will_be_better.md https://www.kirupa.com/hodgepodge/ai/learning_typescript.md https://www.kirupa.com/hodgepodge/ai/preserving_pixel_art_aesthetics.md https://www.kirupa.com/hodgepodge/ai/reading_argb_rgb_color_values.md https://www.kirupa.com/hodgepodge/ai/thinking_about_8k_resolution.md https://www.kirupa.com/hodgepodge/ai/ui_virtualization.md ## Hodgepodge (Plain Text Versions) https://www.kirupa.com/hodgepodge/ai/chrome_dev_tools_for_frontend_developers.txt https://www.kirupa.com/hodgepodge/ai/compiling_transpiling.txt https://www.kirupa.com/hodgepodge/ai/cookies_local_session_storage.txt https://www.kirupa.com/hodgepodge/ai/counting_binary_hexadecimal.txt https://www.kirupa.com/hodgepodge/ai/counting_hexadecimal.txt https://www.kirupa.com/hodgepodge/ai/counting_negabinary.txt https://www.kirupa.com/hodgepodge/ai/fun_look_calculating_pi.txt https://www.kirupa.com/hodgepodge/ai/google_tips_every_developer_should_know.txt https://www.kirupa.com/hodgepodge/ai/if_you_wait_long_enough_perf_will_be_better.txt https://www.kirupa.com/hodgepodge/ai/learning_typescript.txt https://www.kirupa.com/hodgepodge/ai/preserving_pixel_art_aesthetics.txt https://www.kirupa.com/hodgepodge/ai/reading_argb_rgb_color_values.txt https://www.kirupa.com/hodgepodge/ai/thinking_about_8k_resolution.txt https://www.kirupa.com/hodgepodge/ai/ui_virtualization.txt ## Podcast (Markdown) https://www.kirupa.com/podcast/ai/den_mcp.md https://www.kirupa.com/podcast/ai/elisa_ai.md https://www.kirupa.com/podcast/ai/pascal.md ## Podcast (Plain Text Versions) https://www.kirupa.com/podcast/ai/den_mcp.txt https://www.kirupa.com/podcast/ai/elisa_ai.txt https://www.kirupa.com/podcast/ai/pascal.txt ## React (Markdown) https://www.kirupa.com/react/ai/accessing_dom_elements.md https://www.kirupa.com/react/ai/avoiding_unnecessary_renders.md https://www.kirupa.com/react/ai/building_your_first_react_app.md https://www.kirupa.com/react/ai/communicating_with_props.md https://www.kirupa.com/react/ai/component_lifecycle.md https://www.kirupa.com/react/ai/component_lifecycle_new.md https://www.kirupa.com/react/ai/component_lifecycle_old.md https://www.kirupa.com/react/ai/components.md https://www.kirupa.com/react/ai/composing_components.md https://www.kirupa.com/react/ai/creating_complex_components.md https://www.kirupa.com/react/ai/creating_single_page_app_react_using_react_router.md https://www.kirupa.com/react/ai/dealing_with_state.md https://www.kirupa.com/react/ai/errata.md https://www.kirupa.com/react/ai/events_in_react.md https://www.kirupa.com/react/ai/from_data_to_ui_in_react.md https://www.kirupa.com/react/ai/functional_components.md https://www.kirupa.com/react/ai/helloworld.md https://www.kirupa.com/react/ai/how_much_to_know_prior_learning_react.md https://www.kirupa.com/react/ai/if_there_is_one_thing_learn_react.md https://www.kirupa.com/react/ai/introducing_react.md https://www.kirupa.com/react/ai/introduction_to_redux.md https://www.kirupa.com/react/ai/meet_jsx_again.md https://www.kirupa.com/react/ai/multi_page_navigation.md https://www.kirupa.com/react/ai/nested_complex_components.md https://www.kirupa.com/react/ai/revisiting_jsx.md https://www.kirupa.com/react/ai/setting_up_react_environment.md https://www.kirupa.com/react/ai/simple_todo_app_react.md https://www.kirupa.com/react/ai/simple_todo_app_react_old.md https://www.kirupa.com/react/ai/simple_todo_app_react_temp.md https://www.kirupa.com/react/ai/smooth_sliding_menu_react_motion.md https://www.kirupa.com/react/ai/styling_in_react.md https://www.kirupa.com/react/ai/transferring_properties.md https://www.kirupa.com/react/ai/updating_react_version.md https://www.kirupa.com/react/ai/using_redux_with_react.md https://www.kirupa.com/react/ai/versions.md https://www.kirupa.com/react/ai/working_with_external_data.md ## React (Plain Text Versions) https://www.kirupa.com/react/ai/accessing_dom_elements.txt https://www.kirupa.com/react/ai/avoiding_unnecessary_renders.txt https://www.kirupa.com/react/ai/building_your_first_react_app.txt https://www.kirupa.com/react/ai/communicating_with_props.txt https://www.kirupa.com/react/ai/component_lifecycle.txt https://www.kirupa.com/react/ai/component_lifecycle_new.txt https://www.kirupa.com/react/ai/component_lifecycle_old.txt https://www.kirupa.com/react/ai/components.txt https://www.kirupa.com/react/ai/composing_components.txt https://www.kirupa.com/react/ai/creating_complex_components.txt https://www.kirupa.com/react/ai/creating_single_page_app_react_using_react_router.txt https://www.kirupa.com/react/ai/dealing_with_state.txt https://www.kirupa.com/react/ai/errata.txt https://www.kirupa.com/react/ai/events_in_react.txt https://www.kirupa.com/react/ai/from_data_to_ui_in_react.txt https://www.kirupa.com/react/ai/functional_components.txt https://www.kirupa.com/react/ai/helloworld.txt https://www.kirupa.com/react/ai/how_much_to_know_prior_learning_react.txt https://www.kirupa.com/react/ai/if_there_is_one_thing_learn_react.txt https://www.kirupa.com/react/ai/introducing_react.txt https://www.kirupa.com/react/ai/introduction_to_redux.txt https://www.kirupa.com/react/ai/meet_jsx_again.txt https://www.kirupa.com/react/ai/multi_page_navigation.txt https://www.kirupa.com/react/ai/nested_complex_components.txt https://www.kirupa.com/react/ai/revisiting_jsx.txt https://www.kirupa.com/react/ai/setting_up_react_environment.txt https://www.kirupa.com/react/ai/simple_todo_app_react.txt https://www.kirupa.com/react/ai/simple_todo_app_react_old.txt https://www.kirupa.com/react/ai/simple_todo_app_react_temp.txt https://www.kirupa.com/react/ai/smooth_sliding_menu_react_motion.txt https://www.kirupa.com/react/ai/styling_in_react.txt https://www.kirupa.com/react/ai/transferring_properties.txt https://www.kirupa.com/react/ai/updating_react_version.txt https://www.kirupa.com/react/ai/using_redux_with_react.txt https://www.kirupa.com/react/ai/versions.txt https://www.kirupa.com/react/ai/working_with_external_data.txt ## Product Development (Markdown) https://www.kirupa.com/product_development/ai/career_growth_secrets.md https://www.kirupa.com/product_development/ai/career_three_body_problem.md https://www.kirupa.com/product_development/ai/creating_perfect_timing.md https://www.kirupa.com/product_development/ai/pulling_off_a_successful_redesign.md ## Product Development (Plain Text Versions) https://www.kirupa.com/product_development/ai/career_growth_secrets.txt https://www.kirupa.com/product_development/ai/career_three_body_problem.txt https://www.kirupa.com/product_development/ai/creating_perfect_timing.txt https://www.kirupa.com/product_development/ai/pulling_off_a_successful_redesign.txt ## AI (Markdown) https://www.kirupa.com/ai/ai/thinking_about_8k_resolution.md https://www.kirupa.com/ai/ai/vibe_coding_expertise_win.md ## AI (Plain Text Versions) https://www.kirupa.com/ai/ai/thinking_about_8k_resolution.txt https://www.kirupa.com/ai/ai/vibe_coding_expertise_win.txt